• Struts2(二)配置


    一、struts2流程分析与工具配置

    1、运行流程

    请求 --》 StrutsPrepareAndExecuteFilter 核心控制器 --》 Interceptors 拦截器(实现代码功能 ) --》 Action 的execute --》 结果页面 Result

    * 拦截器在 struts-default.xml定义

    * 执行拦截器 是 defaultStack 中引用拦截器
    2、 配置struts.xml 提示问题
    DTD约束
    3、 关联struts2源码
    4、 Config Brower 插件使用
    提供在浏览器中查看 struts2 配置加载情况
     
    二、Struts2常用配置
    1、Struts2框架配置文件
    default.properties 该文件保存在 struts2-core-2.3.7.jar 中 org.apache.struts2包里面
    struts-default.xml 该文件保存在 struts2-core-2.3.7.jar
    struts-plugin.xml 该文件保存在struts-Xxx-2.3.7.jar
    struts.xml 该文件是web应用默认的struts配置文件
    struts.properties 该文件是Struts的默认配置文件
    web.xml 该文件是Web应用的配置文件
     
    ps:如果多个文件配置了同一个struts2 常量,则后一个文件中配置的常量值会覆盖前面文件配置的常量值
    2、action的配置 
    2.1 struts.xml 中action的配置元素
      <package> <action> <result> 
    作用 用于声明一个包。用于管理action。 用于声明 一个action 用于确定返回结果类型
    属性 name  用于声明一个包名,包名不能重复。唯一。 action的一个名称。
    是唯一的(在同包内) 它与package中的namespace确定了访问action的路径
    与action中的方法返回值做对比,确定跳转路径。
    默认值是 "success"
    namespace  与action标签的name属性合并确定了一个唯一访问action的路径。默认值 "/" —————无————— —————无—————
    extends  继承的包名 —————无————— —————无—————
    abstrace  可以取值为true/false,如果为true,代表这个包是用于被继承的 —————无————— —————无—————
    class  —————无————— Action类的全名
    class的默认值是 com.opensymphony.xwork2.ActionSupport
    —————无—————
    method  —————无————— 要访问的Action类中的方法的名称,方法无参数 ,返回值为String.
    默认值是 execute
    —————无—————
    type —————无————— —————无—————

    1) dispatcher :Action 转发给 JSP

    2) chain :Action调用另一个Action (同一次请求)

    3) redirect : Action重定向到 JSP

    4) redirectAction :Action重定向到另一个Action

     
    2.2.关于action配置其它细节:
       2.2.1.关于默认值问题(见表格)
        
       2.2.2.关于访问action的路径问题 
        现在的action的配置是:
        <package name="default" namespace="/" extends="struts-default">
         <action name="hello" class="cn.itcast.action.DefaultAction">
          <result>/hello.jsp</result>
         </action>
        </package>
        
        当我们输入:
        http://localhost/struts2_day01_2/a/b/c/hello
        也访问到了action。
        
        原因:struts2中的action被访问时,它会首先查找
         1.namespace="/a/b/c" action的name=hello 没有.
         2.namespace="/a/b action的name=hello 没有
         3.namespace="/a" action的name=hello 没有
         4.namespace="/" action的name=hello 查找到了.   
         如果最后也查找不到,会报404错误.
       
       2.2.3.默认的action。
        作用:处理其它action处理不了的路径。
        <default-action-ref name="action的名称" />
        配置了这个,当访问的路径,其它的action处理不了时,就会执行name指定的名称的action。
        
       2.2.4.action的默认处理类
        在action配置时,如果class不写。默认情况下是 com.opensymphony.xwork2.ActionSupport。
        <default-class-ref class="cn.itcast.action.DefaultAction"/>
        如果设置了,那么在当前包下,默认处理action请的的处理类就为class指定的类。
     
    3.常量配置
       3.1.三种配置方式
         3.1.1struts.xml(应用最多)
        <constant name="常量名称" value="常量值"></constant>
    <constant name="struts.devMode" value="true" />
      3.1.2.struts.properties(基本不使用)   
            struts.devMode = false
       3.1.3.web.xml(了解)
        配置常量,是使用StrutsPrepareAndExecuteFilter的初始化参数来配置的.
    <filter>
        <filter-name>struts2</filter-name>
        <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
        <init-param>
         <param-name>struts.devMode</param-name>
         <param-value>false</param-value>
        </init-param>
    </filter>

    3.2.常用常量

    <!-- 相当于request.setCharacterEncoding("UTF-8"); 解决post请求乱码  -->
        <constant name="struts.i18n.encoding" value="UTF-8"/>
        <!--开发模式下使用, 提供详细报错页面,修改struts.xml后不需要重启服务器 -->
        <constant name="struts.devMode" value="true" />
        <!-- 设置浏览器是否缓存静态内容,默认值为true(生产环境下使用),开发阶段最好关闭 --> 
        <constant name="struts.serve.static.browserCache" value="false" />
        <!-- 设置是否支持动态方法调用,true为支持,false不支持.  -->
        <constant name="struts.enable.DynamicMethodInvocation" value="true"/>
        <!-- 该属性指定需要Struts 2处理的请求后缀,该属性的默认值是action,即所有匹配*.action的请求都由Struts2处理。 如果用户需要指定多个请求后缀,则多个后缀之间以英文逗号(,)隔开 -->
        <constant name="struts.action.extension" value="do,action" />
     4.struts.xml文件分离 配置
    目的:就是为了阅读方便。可以让一个模块一个配置文件
     
    <struts>
        <include file="book.xml"/>
    </struts>
     
    三、Action类
    1.关于Action类的创建方式(三种)
    1.1创建一个POJO类.
       优点:无耦合。
       缺点:所以工作都要自己实现。
       在struts2框架底层是通过反射来操作:
        * struts2框架 读取struts.xml 获得 完整Action类名 
        * obj = Class.forName("完整类名").newInstance();
        * Method m = Class.forName("完整类名").getMethod("execute"); m.invoke(obj); 通过反射 执行 execute方法
    1.2.创建一个类,实现Action接口. com.opensymphony.xwork2.Action
       
       优点:耦合低。提供了五种结果视图,定义了一个行为方法。
       缺点:所以工作都要自己实现。
     
     public static final String SUCCESS = "success"; // 数据处理成功 (成功页面)
       public static final String NONE = "none"; // 页面不跳转 return null; 效果一样
       public static final String ERROR = "error"; // 数据处理发送错误 (错误页面)
       public static final String INPUT = "input"; // 用户输入数据有误,通常用于表单数据校验 (输入页面)
       public static final String LOGIN = "login"; // 主要权限认证 (登陆页面)
    1.3.创建一个类,继承自ActionSupport类. com.opensymphony.xwork2.ActionSupport
       ActionSupport类实现了Action接口。
       优点:表单校验、错误信息设置、读取国际化信息 三个功能都支持.
       缺点:耦合度高。
      在开发中,第三种会使用的比较多.
     
    2.action类的访问
    2.1.通过设置method的值,来确定访问action类中的哪一个方法
    2.1.1.在struts.xml文件中
        <action name="book_add" class="cn.itcast.action.BookAction" method="add"></action>
    2.1.2.2.在jsp页面上(book.jsp
         <a href="${pageContext.request.contextPath}/book_add">book add</a><br>
    2.2.使用通配符来简化配置
    2.2.1.在struts.xml文件中
        <action name="*_*" class="cn.itcast.action.{1}Action" method="{2}"></action>
    2.2.2.在jsp页面上
        <a href="${pageContext.request.contextPath}/Book_add">book add</a><br>
    当访问book add时,这时的路径是 Book_add,那么对于struts.xml文件中.
        第一个星就是 Book
        第二个星就是 add
        对于{1}Action---->BookAction
        对于method={2}--->method=add
        
       使用通配符来配置注意事项:
        1.必须定义一个统一的命名规范。
        2.不建议使用过多的通配符,阅读不方便。
    2.3.动态方法调用 (了解)
    2.3.1 动态方法调用设置
    struts.enable.DynamicMethodInvocation = true
    2.3.2 在struts.xml文件中
         <action name="book" class="cn.itcast.action.BookAction"></action>
       访问时路径: http://localhost/struts2_day01_2/book!add
        就访问到了BookAction类中的add方法。
     
    3.Action访问Servlet
    3.1、 在Action 中解耦合方式 间接访问 Servlet API 
    3.2、 使用接口注入的方式,操作Servlet API (耦合)
    ServletContextAware : 注入ServletContext对象
    ServletRequestAware :注入 request对象
    ServletResponseAware : 注入response对象
    3.3、 在Action中直接通过 ServletActionContext 获得Servlet API
    ServletActionContext.getRequest() : 获得request对象 (session)
    ServletActionContext.getResponse() : 获得response 对象
    ServletActionContext.getServletContext() : 获得ServletContext对象
     
    四、Result结果类型
    1、 局部结果页面 和 全局结果页面 
    <action name="result" class="cn.itcast.struts2.demo6.ResultAction">
         <!-- 局部结果 当前Action使用 -->
        <result name="success">/demo6/result.jsp</result> 
    </action>
     
    <global-results>
       <!-- 全局结果 当前包中 所有Action都可以用-->
       <result name="success">/demo6/result.jsp</result>
    </global-results>

    2、结果页面跳转类型

           * 在struts-default.xml 定义了 一些结果页面类型

           * 使用默认type 是 dispatcher 转发 (request.getRequestDispatcher.forward)

    1) dispatcher :Action 转发给 JSP

    2) chain :Action调用另一个Action (同一次请求)

           <result name="success" type="chain">hello</result>  hello是一个Action的name

    3) redirect : Action重定向到 JSP

    4) redirectAction :Action重定向到另一个Action

           <result name="success" type="redirectAction">hello</result>

     
  • 相关阅读:
    C结构体中数据的内存对齐问题
    vs2010编译vtk5.8.0 release版本失败的解决方法
    C/C++堆、栈及静态数据区详解 (转载)
    总结一下最近一个月在深圳做的东西
    Stack overflow的问题
    完美的js验证网址url(正则表达式)
    ArrayList,Vector,LinkedList的存储性能和特性
    web程序优化
    巧用 Windows 键盘快捷键
    禁止右键
  • 原文地址:https://www.cnblogs.com/shelly0307/p/10759288.html
Copyright © 2020-2023  润新知