一、概念
Struts 2是在 struts 1和WebWork的技術基礎上進行了合併的全新的Struts 2框架。以WebWork爲核心,採用攔截器的機制來處理用戶的請求,使得業務邏輯控制器能夠與ServletAPI完全脫離開。
二、環境
下載地址:https://struts.apache.org/download.cgi#struts25101
需要多個jar包,最低需求是4M的那一個
三、配置
1.web.xml
<!-- struts2 -->
<filter>
<filter-name>struts2_test</filter-name>
<filter-class>org.apache.struts2.dispatcher.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2_test</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
2.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>
<package name="user" extends="struts-default">
<!-- 測試 -->
<action name="user_add_test" class="web_frame.UserAddAction" method="add">
<result>/success.jsp</result>
</action>
</package>
</struts>
詳細示例(來源http://it.warmtel.com/?p=1846)
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN" "http://struts.apache.org/dtds/struts-2.0.dtd" >
<struts>
<!-- include節點是struts2中組件化的方式 可以將每個功能模塊獨立到一個xml配置文件中 然後用include節點引用 -->
<include file="struts-default.xml"></include>
<!--
package提供了將多個Action組織爲一個模塊的方式
package的名字必須是唯一的, package可以擴展 當一個package擴展自
另一個package時該package會在本身配置的基礎上加入擴展的package
的配置 父package必須在子package前配置
name:package名稱
extends:繼承的父package名稱
abstract:設置package的屬性爲抽象的 抽象的package不能定義action 值true:false
namespace:定義package命名空間 該命名空間影響到url的地址
-->
<package name="com.kay.struts2" extends="struts-default" namespace="/test">
<interceptors>
<!-- 定義攔截器 name:攔截器名稱 class:攔截器類路徑 -->
<interceptor name="timer" class="com.kay.timer"></interceptor>
<interceptor name="logger" class="com.kay.logger"></interceptor>
<!-- 定義攔截器棧 -->
<interceptor-stack name="mystack">
<interceptor-ref name="timer"></interceptor-ref>
<interceptor-ref name="logger"></interceptor-ref>
</interceptor-stack>
</interceptors>
<!-- 定義默認的攔截器 每個Action都會自動引用
如果Action中引用了其它的攔截器 默認的攔截器將無效 -->
<default-interceptor-ref name="mystack"></default-interceptor-ref>
<!-- 全局results配置 -->
<global-results>
<result name="input">/error.jsp</result>
</global-results>
<!-- Action配置 一個Action可以被多次映射(只要action配置中的name不同)
name:action名稱
class: 對應的類的路徑
method: 調用Action中的方法名
-->
<action name="hello" class="com.kay.struts2.Action.LoginAction">
<!-- 引用攔截器 name:攔截器名稱或攔截器棧名稱 -->
<interceptor-ref name="timer"></interceptor-ref>
<!-- 節點配置
name : result名稱 和Action中返回的值相同
type : result類型 不寫則選用superpackage的type struts-default.xml中的默認爲dispatcher
-->
<result name="success" type="dispatcher">
/talk.jsp
</result>
<!-- 參數設置 name:對應Action中的get/set方法 -->
<param name="url">http://www.sina.com</param>
</action>
</package>
</struts>
struts.properties(文件名不能錯,需要在src目錄下)
來源http://it.warmtel.com/?p=1846
#是否開啓開發模式
struts.devMode=true
#所有匹配*.action的請求都由struts2處理
struts.action.extension=do
#struts配置文件改動後,是否重新加載
struts.configuration.xml.reload=true
#請求參數的編碼方式
struts.i18n.encoding=UTF-8
#每次HTTP請求系統都重新加載資源文件,有助於開發
struts.i18n.reload=true
#文件上傳最大值
struts.multipart.maxSize=102400
#設置上傳文件臨時目錄 set place to fileupload of tempfile
struts.multipart.saveDir=d:/temp
#讓struts2支持動態方法調用
struts.enable.DynamicMethodInvocation=true
#允許標籤中使用表達式語法
struts.tag.altSyntax=true
四、動態調用
1.method
<!-- 查詢 -->
<action name="query_user" class="com.user.servlet.OperationUserAction" method="query">
<result>/jsp/user_main.jsp</result>
</action> -->
<!-- 預-增加 -->
<action name="pre_add_user" class="com.user.servlet.OperationUserAction" method="preAdd">
<result>/jsp/update_frame.jsp</result>
</action>
<!-- 預-修改 -->
<action name="pre_update_user" class="com.user.servlet.OperationUserAction" method="preUpdate">
<result>/jsp/update_frame.jsp</result>
</action>
<!-- 增加或者修改 -->
<action name="update_user" class="com.user.servlet.OperationUserAction" method="update">
<result type="redirect">/query_user</result>
</action>
<!-- 刪除 -->
<action name="delete_user" class="com.user.servlet.OperationUserAction" method="delete">
<result type="redirect">/query_user</result>
</action>
2.!
說明:訪問的時候採用”!方法名”
<action name="user" class="com.user.servlet.OperationUserAction">
<!-- 查詢 -->
<result name="query">/jsp/user_main.jsp</result>
<!-- 預-增加 -->
<result name="pre_add">/jsp/update_frame.jsp</result>
<!-- 預-修改 -->
<result name="pre_update">/jsp/update_frame.jsp</result>
<!-- 增加或者修改 -->
<result name="update" type="redirect">/query_user</result>
<!-- 刪除 -->
<result name="delete" type="redirect">/query_user</result>
</action>
3.通配符*
<!-- 解決struts2.5 通配符調用無效的問題 -->
<global-allowed-methods>regex:.*</global-allowed-methods>
<action name="*_user" class="com.user.servlet.OperationUserAction" method="{1}">
<!-- 查詢 -->
<result name="query">/jsp/user_main.jsp</result>
<!-- 預-增加 -->
<result name="pre_add">/jsp/update_frame.jsp</result>
<!-- 預-修改 -->
<result name="pre_update">/jsp/update_frame.jsp</result>
<!-- 增加或者修改 -->
<result name="update" type="redirect">/query_user</result>
<!-- 刪除 -->
<result name="delete" type="redirect">/query_user</result>
</action>
五、接收請求
1.request
HttpServletRequest request = ServletActionContext.getRequest();
ServletActionContext中有相應的靜態方法可以獲取對象,可以像使用servlet那樣獲取參數。
2.屬性
public class LoginAction extends ActionSupport{
private String username;
private String password;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
3.DomainModel
public class LoginAction extends ActionSupport{
private Users users;
public Users getUsers(){
return users;
}
public void setUsers(Users users){
this.users=users;
}
}
4.implements ModelDriven
public class OperationUserAction extends ActionSupport implements ModelDriven<User>{
private User user = new User();
@Override
public User getModel() {
return user;
}
}
六、響應數據
1.ServletActionContext
說明:靜態方法獲取對象,設置屬性
2.實現對應的Aware
public class OperationUserAction extends ActionSupport implements RequestAware{
private Map<String, Object> requestMap;
@Override
public void setRequest(Map<String, Object> request) {
this.requestMap = request;
}
/* 查詢 */
public String query() {
```
/* 根據查詢的條件查詢數據 */
List<User> userList = userService.query(page);
/* 返回的數據放在屬性中,以傳遞到界面 */
requestMap.put("userDto", userDto);
requestMap.put("user_list", userList);
requestMap.put("user_page", page);
return "query";
}
}