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"; } }
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>
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>
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{ }