我是靠谱客的博主 高贵枕头,最近开发中收集的这篇文章主要介绍Struts2 配置文件,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

Struts2 应用程序所需的基本配置,包括配置一些重要的配置文件:web.xmlstruts.xmlstruts-config.xml以及struts.properties

在个人实际项目中使用web.xml和struts.xml这两个配置文件来运行项目,不过为了了解更多,还是再来说明一下其他的文件。

1. web.xml文件

web.xml配置文件是一种J2EE配置文件,决定servlet容器的HTTP元素需求如何进行处理。它严格来说不是一个Struts2 配置文件,但它是Struts2 运作所需要进行配置的文件。正如前面所讨论的,这个文件为每个web应用程序提供接入点。在部署描述符(web.xml)中,Struts2 应用程序的接入点将会定义为一个过滤器。因此我们将在web.xml里定义一个FilterDispatcher类的接入点,而这个web.xml文件需要在WebRoot/WEB-INF文件夹下创建。 

如果你开始时没有模板或工具(比如Eclipse或Maven2)的辅助来生成,那这就是第一个你需要配置的文件。下面是实际项目中用到的web.xml的内容。

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee"  xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
   <display-name>itcastActiviti</display-name>
   <filter>
    <filter-name>encodingFilter</filter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    <init-param>
      <param-name>encoding</param-name>
      <param-value>UTF-8</param-value>
    </init-param>
    <init-param>
      <param-name>forceEncoding</param-name>
      <param-value>true</param-value>
    </init-param>
  </filter>
  <filter-mapping>
    <filter-name>encodingFilter</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>
  
  <servlet>
    <display-name>FileUploadServlet</display-name>
    <servlet-name>FileUploadServlet</servlet-name>
    <servlet-class>cn.itcast.ssh.utils.FileUploadServlet</servlet-class>
  </servlet>
   
  <servlet-mapping>
    <servlet-name>FileUploadServlet</servlet-name>
    <url-pattern>/FileUploadServlet</url-pattern>
  </servlet-mapping>
  <context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:applicationContext.xml</param-value>
  </context-param>
  <listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  </listener>
  <filter>
    <filter-name>struts2</filter-name>
    <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
  </filter>
  <filter-mapping>
    <filter-name>struts2</filter-name>
    <url-pattern>*.action</url-pattern>
  </filter-mapping>
  <welcome-file-list>
    <welcome-file>login.jsp</welcome-file>
  </welcome-file-list>
</web-app>

注意,我们将Struts2 过滤器映射到  /*.action ,这意味着只有*.action的url才会被Struts过滤器解析。

struts.xml文件

struts.xml文件包含有随着Actions的开发 将要修改的配置信息。它可用于覆盖应用程序的默认设置,例如:struts.devMode=false 以及其他定义为属性文件的设置。这个文件可在resource文件夹下创建。

让我们来看一下实际项目中创建的struts.xml文件。

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
	"-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
	"http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>
    <!-- 配置模式为开发模式,自动加载struts.xml和显示错误提示信息 -->
    <constant name="struts.devMode" value="false" />
    <!-- 设置页面主题为简单主题,去掉struts2开发提供的样式 -->
    <constant name="struts.ui.theme" value="simple" />

    <package name="default" namespace="/" extends="struts-default">
    	<!-- 全局结果视图 -->
    	<global-results>
    		<result name="login" type="redirect">
    			login.jsp
    		</result>
    	</global-results>
        <action name="meetingAction_*" class="meetingAction" method="{1}">
    	    <result name="getlist">WEB-INF/views/meeting/list.jsp</result>
        	<result name="list" type="stream">
			    <param name="contentType">text/html</param>
       			<param name="inputName">inputStream</param>
            </result> 
            <result name="input">WEB-INF/views/meeting/input.jsp</result>
            <result name="update" type="redirectAction">
        		<param name="actionName">meetingAction_getlist.action</param>
        	</result>
            <result name="save" type="redirectAction">
        		<param name="actionName">meetingAction_getlist.action</param>
        	</result>
        	<result name="delete" type="redirectAction">
        		<param name="actionName">meetingAction_getlist.action</param>
        	</result>       	
        	<result name="onstafflist">WEB-INF/views/meeting/onstafflist.jsp</result>
        	<result name="checkApplyLeave" type="stream">
			    <param name="contentType">text/html</param>
       			<param name="inputName">inputStream</param>
            </result>
        </action>
        <action name="dutyScheduleAction_*" class="dutyScheduleAction" method="{1}">
    	   <!--  <result name="getlist">WEB-INF/views/meeting/calendar.jsp</result> -->
    	    <result name="getlist">WEB-INF/views/dutyschedule/list.jsp</result>
    	    <result name="list" type="stream">
			    <param name="contentType">text/html</param>
       			<param name="inputName">inputStream</param>
            </result> 
    	     <result name="getadminlist">WEB-INF/views/meeting/calendar_admin.jsp</result>
        	<result name="show" type="stream">
			    <param name="contentType">text/html</param>
       			<param name="inputName">inputStream</param>
            </result> 
            <result name="showevents" type="stream">
			    <param name="contentType">text/html</param>
       			<param name="inputName">inputStream</param>
            </result>
           <result name="save" type="redirectAction">
        		<param name="actionName">dutyScheduleAction_getlist.action</param>
        	</result>
        	<result name="update" type="redirectAction">
        		<param name="actionName">dutyScheduleAction_getlist.action</param>
        	</result>
            <result name="delete" type="redirectAction">
        		<param name="actionName">dutyScheduleAction_getlist.action</param>
        	</result>
            <result name="validAvailable" type="stream">
			    <param name="contentType">text/html</param>
       			<param name="inputName">inputStream</param>
            </result>  	
        	
        </action>
    	<action name="loginAction_*" class="loginAction" method="{1}">
    		<!-- <result name="success">WEB-INF/views/main.jsp</result> -->
        	 <result name="success">bgpt/main_bgpt.jsp</result>
        	<!--  <result name="success" type="redirectAction">
        		<param name="actionName">holidayApplyAction_input.action</param>
        	</result> -->
        	<result name="top">WEB-INF/views/top.jsp</result>
        	<result name="left">WEB-INF/views/left.jsp</result>
        	<result name="welcome">WEB-INF/views/welcome.jsp</result>
        </action>
    </package>
</struts>

首先要注意的是DOCTYPE(文档类型)。如我们的示例所示,所有的Struts配置文件都需要有正确的doctype。<struts>是根标记元素,在其下,我们使用<package>标签声明不同的包。 这里的<package>标签允许配置的分离和模块化。这在你进行一个大的项目并且项目分为多个不同的模块时,是非常有用的。

Struts.xml文件可以随着时间的推移而增长,因此通过包打破它是使它模块化的一种方式,但struts提供了另一种模块化struts.xml文件的方法,你可以将文件拆分为多个xml文件,并用以下方式导入它们。

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
    "http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
     <include file="my-struts1.xml"/>
     <include file="my-struts2.xml"/>
</struts>

我们没有覆盖的另一个配置文件是struts-default.xml。此文件包含Struts的标准配置设置,你不必再为99.99%的项目重复这些设置。 因此,不深入了解这个文件的太多细节.

引用:struts2教程 https://www.w3cschool.cn/struts_2/?

最后

以上就是高贵枕头为你收集整理的Struts2 配置文件的全部内容,希望文章能够帮你解决Struts2 配置文件所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(54)

评论列表共有 0 条评论

立即
投稿
返回
顶部