一、獲取struts2前端
二、選擇经常使用jar包web
path:Struts文件下/lib/...apache
经常使用jar包有session
三、導入jar包到項目下app
導入到WebRoot下的WEB-INF/lib,然後buildPathjsp
四、配置filter(web.xml)工具
五、創建Action(三種方式,類名規範:類的結尾為Action,eg: DefaultAction)ui
5.1.一、創建一個類繼承ActionSupport類(最好)url
5.1.二、複寫方法(返回值為String并且拋出一個異常)spa
5.2.一、直接創建一個普通類
5.2.二、在struts中配置就ok了
5.3.一、創建一個類繼承Action接口
5.3.二、複寫方法(返回值為String并且拋出一個異常)
5.四、配置Struts.xml文件,注意,該文件必須放在src文件夾下,且命名正確
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.5//EN" "http://struts.apache.org/dtds/struts-2.5.dtd"> <struts> <!-- 使用動態方法調用時所需配置 --> <constant name="struts.devMode" value="true"></constant> <constant name="struts.enable.DynamicMethodInvocation" value="true"></constant> <!-- name:配置包名 extends=struts-default為固定 --> <!-- 虛擬資源路徑 eg:若namespace="/xxx" 則要訪問此package下的action,url為webPath/xxx/actionName --> <package name="MyPackage" namespace="/" extends="struts-default"> <!-- 動態調用時配置 --> <global-allowed-methods>這裡寫入*允許被動態調用的方法名,如Login</global-allowed-methods> <!--配置action name->url-pattern method->調用action中指定的一個方法 --> <action name="LoginAction" class="com.struts.web.UserAction" method="execute"> <!--依據execute的返回值來決定跳轉(默認為請求轉發) 配置type決定重定向--> <result name="success" type="redirect">/index.jsp</result> <result name="error">/index.jsp</result> </action> <!-- 動態方法調用(根據url中*的名稱來調用UserAction中對應的方法) eg: url=webRoot/LoginAction_Login時會調用UserLogin下的Login方法 --> <action name="LoginAction_*" class="com.struts.web.UserAction" method="{1}"> </action> </package> </struts>
六、參數傳遞(接收參數)
6.一、屬性驅動方式
在action里聲明對應參數的字段,生成對應的getter和setter,struts會自動獲取request域中同名的參數
6.二、類驅動方式(不推薦)
在action里聲明屬性所屬的類(不用實例化),生成對應的getter和setter,如:User(有username和password屬性並且實現getter和setter方法)
在前端form表單中對應屬性input的name屬性需為,如:name="user.username"
6.三、封裝參數(推薦)
繼承ModelDriven<要封裝的pojo類>接口,複寫getModel()方法:返回實例化的類(注意要先把要封裝的類實例化,且這個類要有getter和setter)
(與servlet區別,servlet的數據封裝是通過導入BeanUtils工具包對對象進行封裝,方便數據類型轉換)
七、傳遞參數(ActionContext)
ActionContext的數據結構是Map,存儲了一下(對象:對象地址)
request、response、servletContext(application)、session、attr域、param域、valueStack。。。
//经常使用方法
ActionContext.getContext().put(key, value) == servlet中 request.setAttribute(key, value) //get同理
ActionContext.getContext().getSession() 獲取session,返回Map對象,使用put、get對應存取
ActionContext.getContext().getApplication() 獲取servletContext,返回Map對象,使用put、get對應存取
PS:ActionContext的生命週期:每次請求都會創建一個與請求對應的ActionContext對象,請求處理完,ActionContext就會被銷毀
通過ActionContext的子類ServletActionContext能够獲得原生的request、response
八、action的方法规范:
一、返回值是String(也能够是void)
二、没有参数
三、用public修饰
九、ognl(升级版的jstl)的使用
一、再jsp文件中加上<%@taglib uri="/struts-tags" prefix="s"%>
二、经常使用标签:
2.一、循环
<s:iterator value=" 做用域中(存的某个对象)的键名 " var=" 给每一次循环的内容用一个变量表示 ">
循环体:
获取对象的某个值<s:property value=" 对象中对应的属性名,如UserName "/>
</s:iterator>
2.二、判断:
<s:if test=" 逻辑判断 "></s:if><s: else></s:else>
2.三、获取对象中的某个字段
<s:propety value="#ObjectName.属性名(有对应的getter)"/>(# == ActionContext.getContext())
因为它实际上是用ActionContext去取值,那么就会有做用域前后问题:pageContext --> HttpSession --> ServletContext
十、action获取request中值的三种方法:
属性驱动:
表单获取数据(属性)---->struts(params拦截器)---->ognl---->valueStack---->对应action属性值
对象驱动
表单获取数据(ObjectName.属性)---->struts(params拦截器)---->ognl---->valueStack---->对应action里的对象---->对象的属性
模型驱动
表单获取数据(属性)---->struts(params拦截器)---->ognl---->valueStack------>直接找root中对应的对象(在action中已实例化,modelDriver将实例化的对象压入ValueStack)--->对象中的属性名
十二、Action原理
request ---> 前端控制器(FC) ---> struts(拦截器) ---> action与jsp数据交互的媒介:valueStack(root栈、actionContext、ognl引擎) ---> struts建立action ----> 当全部的拦截器(一、二、3)拦截完后 ---> 将action压入root栈 ---> 执行action ---> 反向执行拦截器(三、二、1)---> FC建立result结果集 ---> 转发或重定向
1三、result结果集(输出的处理):
每一个result是一个类,每一个类都实现了共同的接口Result,struts2预置了10种类型的result,它们被定义在struts-default.xml(在package的extends=“structs-default”就是声明继承struts-default,继承了才能使用result标签)中
四种经常使用type:
dispatcher转发:默认
chain:转发到action
redirect:重定向
redirectAction:重定向到Action
1四、拦截器(拦截器只能控制访问Action,不能控制访问jsp)实现:
第一种(推荐):
建立:建立一个类继承MethodFilterInterceptor
复写String doIntercept(ActionInvocation invocation)方法(放行 invocation.invoke())
第二种:
建立:建立一个类实现Intercept接口
实现String intercept(ActionInvocation invocation)方法(放行同样)
配置(注意:package中配置是有顺序要求的):
Content Model : (result-types?, interceptors?, default-interceptor-ref?, default-action-ref?, default-
class-ref?, global-results?, global-allowed-methods?, global-exception-mappings?, action*)
<!-- name:配置包名 extends=struts-default為固定 --> <!-- 虛擬資源路徑 eg:若namespace="/xxx" 則要訪問此package下的action,url為webPath/xxx/actionName --> <package name="MyPackage" namespace="/" extends="struts-default"> <interceptors> <!-- 注册拦截器 --> <interceptor name="myIntercept" class="com.struts.intercept.MyIntercept"></interceptor> <!-- 注册拦截器栈 --> <interceptor-stack name="myStack"> <!-- 引入本身建立的拦截器 --> <interceptor-ref name="myIntercept"> <!-- 配置不通过此拦截器的方法(login方法不只过拦截器) --> <param name="excludeMethods">login</param> </interceptor-ref> <!-- 引入struts自己的拦截器(20) --> <interceptor-ref name="defalutStack"></interceptor-ref> </interceptor-stack> </interceptors> <!-- 指定包中的默认拦截器栈(不指定则用struts的默认) --> <default-interceptor-ref name="myStack"></default-interceptor-ref> <!-- 配置全局结果集(配合拦截器) --> <global-results> <result name="toLogin" type="redirect">/login.jsp</result> </global-results>