Struts2是一个基于MVC设计模式的Web应用框架,它本质上至关于一个servlet,在MVC设计模式中,Struts2做为控制器(Controller)来创建模型与视图的数据交互。Struts 2是Struts的下一代产品,是在 struts 1和WebWork的技术基础上进行了合并的全新的Struts 2框架。其全新的Struts 2的体系结构与Struts 1的体系结构差异巨大。Struts 2以WebWork为核心,采用拦截器的机制来处理用户的请求,这样的设计也使得业务逻辑控制器可以与ServletAPI彻底脱离开,因此Struts 2能够理解为WebWork的更新产品。虽然从Struts 1到Struts 2有着太大的变化,可是相对于WebWork,Struts 2的变化很小。java
1.导包
在Struts2的zip包下的apps中找到struts2-blank.war,用解压软件打开,lib就是所须要的jar包web
2.书写Action类apache
package cn.zhli13.a_hello; public class HelloAction { public String hello () { System.out.println("hello_word"); return "success"; } }
3.书写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.zhli13.a_hello.HelloAction" method="hello"> <result name="success">/hello.jsp</result> </action> </package> </struts>
4.将Struts核心过滤器配置到web.xmlapi
<?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/web-app_2_5.xsd" 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>strus2_demo</display-name> <!-- Struts核心过滤器 --> <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> </web-app>
5.测试结果架构
6.流程图app
struts.xml配置框架
<!-- i18n:国际化. 解决post提交乱码 --> <constant name="struts.i18n.encoding" value="UTF-8"></constant> <!-- 指定访问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> <!-- package:将Action配置封装.就是能够在Package中配置不少action. name属性: 给包起个名字,起到标识做用.随便起.不能其余包名重复. namespace属性:给action的访问路径中定义一个命名空间 extends属性: 继承一个 指定包 abstract属性:包是否为抽象的; 标识性属性.标识该包不能独立运行.专门被继承 --> <package name="hello" namespace="/hello" extends="struts-default" > <!-- action元素:配置action类 name属性: 决定了Action访问资源名. class属性: action的完整类名 method属性: 指定调用Action中的哪一个方法来处理请求 --> <action name="HelloAction" class="cn.itheima.a_hello.HelloAction" method="hello" > <!-- result元素:结果配置 name属性: 标识结果处理的名称.与action方法的返回值对应. type属性: 指定调用哪个result类来处理结果,默认使用转发. 标签体:填写页面的相对路径 --> <result name="success" type="dispatcher" >/hello.jsp</result> </action> </package> <!-- 引入其余struts配置文件 --> <include file="cn/zhli13/b_dynamic/struts.xml"></include>
2.struts常量配置jsp
struts2默认常量配置位置ide
修改struts2常量配置(方式前后也是加载顺序)
方式1:src/struts.xml(主要) <!-- i18n:国际化. 解决post提交乱码 --> <constant name="struts.i18n.encoding" value="UTF-8"></constant> 方式2:在src下建立struts.properties struts.i18n.encoding=UTF8 方式3:在项目的web.xml中 <context-param> <param-name>struts.i18n.encoding</param-name> <param-value>UTF-8</param-value> </context-param>
3.struts2配置的进阶
动态方法调用
方式1: <!-- 配置动态方法调用是否开启常量 默认是关闭的,须要开启 访问时方法名前要添加!符号 --> <constant name="struts.enable.DynamicMethodInvocation" value="false"></constant> 方式2: <package name="dynamic" namespace="/dynamic" extends="struts-default" > <!-- 动态方法调用方式2:通配符方式 使用{1} 取出第一个星号通配的内容 --> <action name="Demo1Action_*" class="cn.zhli13.b_dynamic.Demo1Action" method="{1}" > <result name="success" >/hello.jsp</result> </action> </package>
struts2中的默认配置
<package name="default" namespace="/default" extends="struts-default" > <!-- 找不到包下的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 name="Demo2Action" > <result >/hello.jsp</result> </action> </package>
Action类的书写方式
方式1 package cn..d_api; //方式1: 建立一个类.能够是POJO //POJO:不用继承任何父类.也不须要实现任何接口. //使struts2框架的代码侵入性更低. public class Demo3Action { } //方式2: 实现一个接口Action // 里面有execute方法,提供action方法的规范. // Action接口预置了一些字符串.能够在返回结果时使用.为了方便 import com.opensymphony.xwork2.Action; public class Demo4Action implements Action { @Override public String execute() throws Exception { return null; } } //方式3: 继承一个类.ActionSupport // 帮咱们实现了 Validateable, ValidationAware, TextProvider, LocaleProvider . //若是咱们须要用到这些接口的实现时,不须要本身来实现了. import com.opensymphony.xwork2.ActionSupport; public class Demo5Action extends ActionSupport{ }