• struct2


    struts2

    概念:处理访问服务器的请求, 代替servlet 处理表单页面的请求

    使用优势:自动封装参数 参数校验  结果处理(转发重定向)  国际化  显示等待页面  表单的防止重复提交

        具有更加先进的架构以及思想

    struts1历史:  2与1区别就是技术上没有什么关系,Struts2 是 WebWork 的升级,跟 Struts1 无关; 1是基于servlet,servlet线程不安全(线程不安全的概念); 2基于Filter,摆脱线程安全问题

    搭建框架

    1.导包   struts-2.3.24-all.zip  李有

    2书写action类

    package cn.itheima.a_hello;
    
    public class HelloAction {
    
        public String hello(){
            
            System.out.println("hello world!");
            
            return "success";
        }
        
    }
    View Code

    3.书写src/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>
        <package name="hello" namespace="/hello" extends="struts-default">
            <action name="HelloAction" class="cn.heima.a_hello.HelloAction" method="hello">
                <result name="success">/hello.jsp</result>
            </action>
        </package>
    </struts>
    View Code

    4将struts2核心过滤器配置到web.xml

      <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>/*</url-pattern>
      </filter-mapping>
    View Code

    struts访问流程

    aop面向切面编程思想

     

    配置详解

    1.struct2核心配置   src/struts.xml

        <package name="hello" namespace="/hello" extends="struts-default">
            <action name="HelloAction" class="cn.heima.a_hello.HelloAction" method="hello">
                <result name="success">/hello.jsp</result>
            </action>
        </package>

    <!-- package:将Action配置封装.就是可以在Package中配置很多action.
    name属性: 给包起个名字,起到标识作用.随便起.不能其他包名重复.
    namespace属性:给action的访问路径中定义一个命名空间
    extends属性: 继承一个 指定包
    abstract属性:包是否为抽象的; 标识性属性.标识该包不能独立运行.专门被继承
    -->

    <!-- action元素:配置action类
    name属性: 决定了Action访问资源名.
    class属性: action的完整类名
    method属性: 指定调用Action中的哪个方法来处理请求
    -->

    <!-- result元素:结果配置
    name属性: 标识结果处理的名称.与action方法的返回值对应.
    type属性: 指定调用哪一个result类来处理结果,默认使用转发.
    标签体:填写页面的相对路径
    -->

    2常量配置

     默认常量配置位置   src/Libraries/Wep app Libaries下

      /org/apache/struts2/default.properties

    修改常量配置

      三种方式修改 (方式先后也是加载顺序)

      1.src 新建    

      2.在struts.xml中 (重点)

      3.在web.xml中 

     3.常量修改(3个)  default.properties中的默认常量,可在struts.xml中配置

      <!-- i18n:国际化. 解决post提交乱码 -->

    <constant name="struts.i18n.encoding" value="UTF-8"></constant>

      

    <!-- 指定反问action时的后缀名    默认后缀名是action
    http://localhost:8080/struts2_day01/hello/HelloAction.do
    -->
    <constant name="struts.action.extension" value="action"></constant>

    <!-- 指定struts2是否以开发模式运行
    1.热加载主配置.(不需要重启即可生效)
    2.提供更多错误信息输出,方便开发时的调试
    -->
    <constant name="struts.devMode" value="true"></constant>

    3  struts2配置的进阶

      动态方法调用(重点)

        1  

          不符合seo优化,如果不考虑网站推广可以用

        2(推荐)

        

      struts中的默认配置  

    <!-- 找不到包下的action,会使用Demo2Action作为默认action处理请求 -->
    <default-action-ref name="Demo2Action"></default-action-ref>
    <!-- method属性:execute -->
    <!-- result的name属性:success -->
    <!-- result的type属性:dispatcher 转发 -->
    <!-- class属性:com.opensymphony.xwork2.ActionSupport -->

    action类详解

    创建方式

    package cn.itheima.d_api;
    
    //方式1: 创建一个类.可以是POJO
    //POJO:不用继承任何父类.也不需要实现任何接口.
    //使struts2框架的代码侵入性更低.
    public class Demo3Action {
    
    }
    方式一
    package cn.itheima.d_api;
    
    import com.opensymphony.xwork2.Action;
    
    //方式2: 实现一个接口Action
    // 里面有execute方法,提供action方法的规范.
    // Action接口预置了一些字符串.可以在返回结果时使用.为了方便
    public class Demo4Action implements Action {
    
        @Override
        public String execute() throws Exception {
            return null;
        }
    
    }
    方式二
    package cn.itheima.d_api;
    
    import com.opensymphony.xwork2.ActionSupport;
    
    //方式3: 继承一个类.ActionSupport
    // 帮我们实现了 Validateable, ValidationAware, TextProvider, LocaleProvider .
    //如果我们需要用到这些接口的实现时,不需要自己来实现了.
    public class Demo5Action  extends ActionSupport{
    
    }
    方式三
  • 相关阅读:
    P2890 [USACO07OPEN]Cheapest Palindrome G 题解
    「NOIP2021模拟赛 By JXC C」位运算 题解
    AT5759 ThREE 题解
    P7532 [USACO21OPEN] Balanced Subsets P 题解
    linux下的pdf分割合并软件
    Python小练习 SDUT 2521 出现次数
    小问题备查持续更新
    Python小练习自动登录人人发送消息并返回好友列表
    Debian系使用小红点
    linux权限问题学习总结
  • 原文地址:https://www.cnblogs.com/hellowq/p/9523097.html
Copyright © 2020-2023  润新知