1.
Struts2入門及配置
Struts2是基於webwork整合Struts1而產生的新架構,即webwork+struts1=struts2
1.
在[url]http://struts.apache.org/[/url]下載Struts組件
2.
Struts2配置
開發環境
IDE:
Eclipse3.2+MyEclipse5.5
Servlet Container:Tomcat5.0
1.創建一個webproject,使用J2EE1.4,不使用JSTL標籤庫
2.在Tomcat的conf文件夾中修改Server.xml文件,添加
<Context path="/struts2" docBase="D:\src\strust2\WebRoot" reloadble="true" />
——reloadble="true" 設置使當前應用下class文件或配置文件修改後自動重啓Tomcat,正式運行應改false;
3.
設置IDE工做環境
Windows—>perferences—>java—>Installed JRES—>add 須要的JDK
Windows—>perferences—>MyEclipse—>Application Servers—>設置Tomcat
4.
配置Struts2開發環境,解壓下載的Struts2.zip開發包,把lib目錄下的*.jar文件拷貝到WEB項目中的
WebRoot/WEB-INF/lib下:
commons-logging-1.0.4.jar
struts2-core-2.0.12.jar
xwork-2.0.6.jar
ognl-2.6.11.jar
freemarker-2.3.8.jar
5.
配置web.xml文件,在文件中配置Struts2的應用
<filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dipatcher.FilterDispatcher</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
——代碼原意:客戶端全部的請求都要通過FilterDispatcher過濾器處理。
——項目下的src的全部文件編譯後自動放到該項目的WebRoot\WEB-INF\classes下
6.
新建struts.xml文件,並從其它項目的struts.xml複製xml頭部信息,或輸入以下:
<?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.xml文件中配置action類,並進行數據轉發
7.
創建action類,並在struts.xml中配置。
——Action類能夠繼承ActionSupport獲取一些接口的支持
========================================
1.jsp
1.jsp
<form action="login.action" method="post">
username:<input type="text" name="username" /><br/>
password:<input type="password" name="password" /><br/>
<input type="submit" />
</form>
username:<input type="text" name="username" /><br/>
password:<input type="password" name="password" /><br/>
<input type="submit" />
</form>
========================================
2.配置工程
tomcat的conf\server.xml中加入<context>
...
<Host ...>
<Context path="/struts2" 經過localhost:8080/struts2/...jsp 訪問
docBase="D:reflection\prepare\WebRoot" 對應到的具體目錄
reloadable="true" class或配置文件更改時,tomcat會自動重啓,但有時候會很差用
/>
</Host>
</Engine>
</Service>
</Server>
...
<Host ...>
<Context path="/struts2" 經過localhost:8080/struts2/...jsp 訪問
docBase="D:reflection\prepare\WebRoot" 對應到的具體目錄
reloadable="true" class或配置文件更改時,tomcat會自動重啓,但有時候會很差用
/>
</Host>
</Engine>
</Service>
</Server>
========================================
3.加入jar包
commons-logging-1.0.4.jar
freemarker-2.3.8.jar
ognl-2.6.11.jar
struts2-core-2.0.11.1.jar
xwork-2.0.4.jar
freemarker-2.3.8.jar
ognl-2.6.11.jar
struts2-core-2.0.11.1.jar
xwork-2.0.4.jar
========================================
4.添加過濾器
4.添加過濾器
在項目的web.xml中加入struts2的過濾器--做爲struts2的控制器,過濾全部請求
<filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>
</filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name> 對應上面的filter-name
<url-pattern>/*</url-pattern> 客戶端發送的全部請求都由FilterDispatcher來過濾
</filter-mapping>
<filter-name>struts2</filter-name> 對應上面的filter-name
<url-pattern>/*</url-pattern> 客戶端發送的全部請求都由FilterDispatcher來過濾
</filter-mapping>
========================================
5. 創建struts.xml配置文件
必須在WebRoot\WEB-INF\classes\下,因此能夠在src目錄下創建,會保存到classes目錄下
<?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">
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
</struts>
========================================
6.創建Action,不須要依賴任何類文件
6.創建Action,不須要依賴任何類文件
com.test.action.LoginAction
public class LoginAction {
//不須要創建ActionForm類了
private String username;
private String password;
private String username;
private String password;
//setter...getter... method [根據方法名匹配到jsp頁面]
這兩個方法對應到頁面的username\password,而不是屬性對應到頁面的username\password
這兩個方法對應到頁面的username\password,而不是屬性對應到頁面的username\password
public String execute() throws Exception {
return "success";
}
}
}
}
========================================
7.result.jsp
username:${ requestScope.username }<br/> 請求範圍內的username
password:${ requestScope.password } 請求範圍內的password
password:${ requestScope.password } 請求範圍內的password
========================================
8. 配置struts.xml
必須在WebRoot\WEB-INF\classes\下,因此能夠在src目錄下創建,會保存到classes目錄下
<?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">
<!DOCTYPE struts PUBLIC
"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
struts2這個包繼承已經編譯好的內置的struts-default包
<package name="struts2" extends="struts-default">
對應表單的action 對應處理請求的action類
<action name="login" class="com.test.action.LoginAction"
struts2這個包繼承已經編譯好的內置的struts-default包
<package name="struts2" extends="struts-default">
對應表單的action 對應處理請求的action類
<action name="login" class="com.test.action.LoginAction"
處理完以後轉到哪
<result name="success">/result.jsp</result>
<result name="success">/result.jsp</result>
</action>
</package>
</struts>
</package>
</struts>
@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
補充:
補充:
========================================
1.login2.jsp
1.login2.jsp
加入Struts標籤
<%@ taglib prefix="s" uri="/struts-tags" %>
<%@ taglib prefix="s" uri="/struts-tags" %>
默認action就不用寫.action了
<s:form action="login" method="post">
label爲在控件前顯示的文字
struts2的標籤自動換行不用加<br/>
<s:textfield name="username" label="用戶名"></s:textfield>
<s:password name="password" label="密碼"></s:password>
<s:form action="login" method="post">
label爲在控件前顯示的文字
struts2的標籤自動換行不用加<br/>
<s:textfield name="username" label="用戶名"></s:textfield>
<s:password name="password" label="密碼"></s:password>
<s:submit label="提交"></s:submit> 默認右對齊
</s>
</s>
========================================
2.action 繼承Struts2的ActionSupport類
2.action 繼承Struts2的ActionSupport類
com.opensymphony.xwork2.ActinSupport;
它集成了不少接口,包括:
Action,Validateable,ValidationAware,TextProvider,LocaleProvider,Serializable
繼承了這個類以後好多功能都繼承好了,好比驗證
它集成了不少接口,包括:
Action,Validateable,ValidationAware,TextProvider,LocaleProvider,Serializable
繼承了這個類以後好多功能都繼承好了,好比驗證
class LoginAction extends ActionSupport
========================================
3.驗證方法(不涉及業務邏輯的判斷)
須要驗證時,須要重寫validate()這個方法
菜單->Sourse->Override/Implement Methods...->選擇validate()
菜單->Sourse->Override/Implement Methods...->選擇validate()
@Override
public void validate() {
//驗證
if(...) {
...
}
}
public void validate() {
//驗證
if(...) {
...
}
}
========================================
4.添加一個錯誤的信息
4.添加一個錯誤的信息
ValidationAware接口的方法
addFieldError(String fieldName, String errorMessage)
對一個指定的字段增長一個錯誤的信息
addFieldError(String fieldName, String errorMessage)
對一個指定的字段增長一個錯誤的信息
errorMessage能夠完成國際化
========================================
5.驗證邏輯
public void validate() {
//驗證
if( this.getUsername() == null || "".equals(this.getUsername().trim()) ) {
this.addFieldError("username"."username required");
//第1個參數爲對應頁面的字段
//第2個參數爲提示信息
//若是出錯,它將在所對應的字段上方劇中對齊顯示提示文字
}
if( this.getUserpassword() == null || "".equals(this.getUserpassword().trim()) ) {
this.addFieldError("userpassword"."userpassword required");
}
}
//驗證
if( this.getUsername() == null || "".equals(this.getUsername().trim()) ) {
this.addFieldError("username"."username required");
//第1個參數爲對應頁面的字段
//第2個參數爲提示信息
//若是出錯,它將在所對應的字段上方劇中對齊顯示提示文字
}
if( this.getUserpassword() == null || "".equals(this.getUserpassword().trim()) ) {
this.addFieldError("userpassword"."userpassword required");
}
}
========================================
6.修改struts.xml 添加<result>
<result name="input">/login2.jsp</result>
name="input" 表示 當validate()中有錯誤的話,它會自動回到input所對應的頁面
用戶名或密碼出錯是跳到這個頁面
<result name="failer">/login2.jsp</result>
<result name="failer">/login2.jsp</result>
========================================
7.業務邏輯的判斷放到execute中
public String execute() throws Exception {
if( "hello".equals(this.getUsername().trim())
&& "world".equals(this.getUserpassword().trim()) ) {
return "success";
}else {
在input頁面的username字段上方顯示 錯誤信息
this.addFieldError("username","username or password error!");
return "failer";
}
}
if( "hello".equals(this.getUsername().trim())
&& "world".equals(this.getUserpassword().trim()) ) {
return "success";
}else {
在input頁面的username字段上方顯示 錯誤信息
this.addFieldError("username","username or password error!");
return "failer";
}
}
========================================
8.getAttribute() 和getParameter()的區別
8.getAttribute() 和getParameter()的區別
getAttribute()是得到從server端set進去的請求
getParameter()是得到從client端提交的請求
getParameter()是得到從client端提交的請求
request.getParameter("username") 至關於: $(requestScope.username)