JavaEE學習筆記之SSH—Struts2(1)
現在來學習SSH中的第二個框架——Struts2
一、strust2框架來歷簡介:
WebWork是由OpenSymphony組織開發的,致力於元件化和程式碼重用的J2EE Web框架。(同時也是一個成熟的基於Web的MVC框架) MVC:Model View Controller, model是模型,view是檢視,controller是控制器,是一種框架模式. 隨著WebWork框架的發展,衍生出了strust2框架,因此strust2框架是WebWork的升級,而不是一個全新的框架,因此穩點性、效能等方面都有很好的保證,而且也同時吸收了struts1框架和WebWork倆者的優點.所以strust2框架也是一個基於Web的MVC框架 注意:strust2框架並不是struts1框架的延續或者升級,倆者有著很大的不同
二、web專案中的三層架構(和MVC是兩個完全不同的架構)
1.表示層(檢視層)
Struts2框架就是工作在這個地方
2.業務邏輯層
service層,處理業務邏輯,比如判斷使用者名稱是否存在、密碼是否正確、許可權是否擁有、賬號是否被凍結、賬號是否異常、使用者積分是否到達操作要求等等,多為一些執行某一個操作條件的判斷
3.資料訪問層
dao層,專門處理和資料庫進行交換的事情,jdbc/hibernate就在這裡使用
在專案中,這些不同的分層的表現形式,其實就是在我們自己建的不同的package中寫上各自分層中所使用的java類.比如在專案中我們建了三個package,三個package中java類的作用分別為表示層的程式碼、業務邏輯層程式碼、資料訪問層程式碼.
注意:可以理解為,MVC架構是這裡說描述的三層架構的一部分,即:三層架構中的表示層可以使用mvc架構的框架來實現,例如使用struts2框架.
三、使用struts2框架的好處(為什麼要使用struts2框架)
減少程式設計人員程式碼的編寫,使程式碼更加簡潔明瞭,縮短開發時間,增加開發效率.
首先將Struts2的框架搭建起來:
1)獲取釋出包
可以從 Struts2官網、Apache、GitHub等,當然直接百度肯定也是可以的。
2)匯入相關 jar 包
將 struts-2.3.24.1-all\struts-2.3.24.1\apps\struts2-blank.war 壓縮檔案解壓,然後將 E:\utils\struts2\struts-2.3.24.1-all\struts-2.3.24.1\apps\struts2-blank\WEB-INF\lib 下的 jar 包全部匯入到專案中 WebContent/WEB-INF/lib 中。
(13個)
struts2-core-2.3.24.1.jar
xwork-core-2.3.24.1.jar
這兩個是核心 jar 包
3)配置 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>*.action</url-pattern>
</filter-mapping>
在web.xml檔案中配置struts2框架的過濾器。這個過濾器的作用:攔截struts2框架中的action.
注意:如果不配置這個filter,struts2框架就不能夠工作.
4)配置 struts2 核心配置檔案 struts.xml
將 struts-2.3.24.1\apps\struts2-blank\WEB-INF\src\java\struts.xml 複製到專案的 src 目錄下。
<?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>
<constant name="struts.enable.DynamicMethodInvocation" value="false" />
<constant name="struts.devMode" value="true" />
<package name="default" namespace="/" extends="struts-default">
</package>
</struts>
這樣 Struts2 框架就搭建好了。
如果在 struts.xml 中不能夠提示或者與警告什麼的,那有可能是 dtd沒有導進來。
解決辦法:
a、先將 struts-2.3.24.1\apps\struts2-blank\WEB-INF\lib 下的 struts2-core-2.3.24.1.jar 解壓開。
b、再在 struts-2.3.24.1\apps\struts2-blank\WEB-INF\lib\struts2-core-2.3.24.1\ 中找到 struts-2.3.dtd 檔案複製到 專案中的 WEB-INF 下。
c、windows ——> preferences ——> 輸入 xml 搜尋 ——> XML Catalog ——> Add
點選 WorkSpace...從專案中找到 struts-2.3.dtd ——> OK
Key type: 選擇 URI
key:輸入 http://struts.apache.org/dtds/struts-2.3.dtd
這樣就應該有提示了,也不會有警告了。
Struts2工作原理
在struts2的應用中,從使用者請求到伺服器返回相應響應給客戶端的過程中,包含了許多元件如:Controller、ActionProxy、ActionMapping、Configuration Manager、ActionInvocation、Inerceptor、Action、Result等。下面我們來具體看看這些元件有什麼聯絡,它們之間是怎樣在一起工作的。
(1) 客戶端(Client)向Action發用一個請求(Request)
(2) Container通過web.xml對映請求,並獲得控制器(Controller)的名字
(3) 容器(Container)呼叫控制器(StrutsPrepareAndExecuteFilter或FilterDispatcher)。在Struts2.1以前呼叫FilterDispatcher,Struts2.1以後呼叫StrutsPrepareAndExecuteFilter
(4) 控制器(Controller)通過ActionMapper獲得Action的資訊
(5) 控制器(Controller)呼叫ActionProxy
(6) ActionProxy讀取struts.xml檔案獲取action和interceptor stack的資訊。
(7) ActionProxy把request請求傳遞給ActionInvocation
(8) ActionInvocation依次呼叫action和interceptor
(9) 根據action的配置資訊,產生result
(10) Result資訊返回給ActionInvocation
(11) 產生一個HttpServletResponse響應
(12) 產生的響應行為傳送給客服端。
四、struts2框架中的Action
struts2框架中有一種java類叫做Action,這種說法就像J2EE專案中有一種java類加Servlet.(人們的生活中有一種人的職業叫警察)struts2框架底層還是封裝了Servlet的相關內容而實現出來的.只不過struts2框架除了servlet的功能以外還擴展出了很多其他的功能,同時還大大簡化了以前在servlet中繁瑣的操作.
在struts2框架中有一種類就是用來代替以前我們在web專案中所使用到的servlet,那麼這種類,在struts2框架中被稱為Action.所以Action其實也是一種java類,比servlet功能更加強大的java類,同時還比servlet中的操作簡單.
五.為什麼Action會有比servlet強大的功能以及簡潔的操作
因為我們在web.xml檔案中配置了struts2框架中專門的過濾器,用作攔截訪問action的請求,攔截住之後,struts2框架就可以給Action新增很多豐富的功能了.
開發 Struts2 專案:
1、搭建好 Struts2 框架
2、編寫 Action
3、配置 Struts.xml
舉個例子來講:
新建個類為 UserAction.java
public class UserAction {
public String toLogin() {
System.out.println("跳轉到登陸頁面");
return "login";
}
public String toRegister() {
System.out.println("跳轉到註冊頁面");
return "register";
}
}
現在 struts.xml 的配置為
<package name="test" namespace="/" extends="struts-default">
<!-- action相當於以前的Servlet的概念,對應一個請求 name的為請求的url地址
localhost:8088/專案名/user_toLogin.action-->
<!-- 直接匹配 -->
<action name="user_*" class="com.briup.week3.web.action.UserAction" method="{1}">
<result name="login">/WEB-INF/jsp/login.jsp</result>
<result name="register">/WEB-INF/jsp/register.jsp</result>
</action>
①首先容器會建立 request 物件並攜帶 url:/user_toRegister.action;
②然後經過 struts2 的過濾器即
<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>*.action</url-pattern>
就變為 /user_toRegister;
③然後經過 struts.xml 中
<package name="test" namespace="/" extends="struts-default">
的 namespace=”/” 就變為 user_toRegister;
④再經過
<action name="user_*" class="com.briup.week3.web.action.UserAction" method="{1}">
中的 name=”user_*” 就變為 toRegister;
⑤然後將會呼叫這個類(class="com.briup.week3.web.action.UserAction")的 toRegister 方法。只知道類名如何呼叫方法,這將會用到 java 中的反射。
Class.forName(“com.briup.week3.web.action.UserAction.class”)
.newInstance()
.toRegister();
呼叫這個之後將會返回一個字串 “register”
⑥最後拿這個字串去和
<result name="login">/WEB-INF/jsp/login.jsp</result>
<result name="register">/WEB-INF/jsp/register.jsp</result>
</action>
中的 name 匹配,將匹配到第二個 result ——> 跳轉到 /WEB-INF/jsp/register.jsp 這個頁面。
在 struts.xml 中,有一個標籤叫做
<constant name="struts.devMode" value="true"></constant>
當然這裡面的常量 name 有許多值,那這些都是從哪裡來呢,我們可以開啟 struts2-core-2.3.29.jar/org/apache/struts2/default.properties,當中就寫了好多配置資訊,都是以鍵值對形式展現。那我們的 constant 標籤的的 name 值就可以從裡面取。
常用常量:
<?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>
<!-- 指定Web應用的預設編碼集,相當於呼叫HttpServletRequest的setCharacterEncoding方法 -->
<constant name="struts.i18n.encoding" value="UTF-8" />
<!--
該屬性指定需要Struts 2處理的請求字尾,該屬性的預設值是action,即所有匹配*.action的請求都由Struts2處理。
如果使用者需要指定多個請求字尾,則多個字尾之間以英文逗號(,)隔開。
-->
<constant name="struts.action.extension" value="do" />
<!-- 設定瀏覽器是否快取靜態內容,預設值為true(生產環境下使用),開發階段最好關閉 -->
<constant name="struts.serve.static.browserCache" value="false" />
<!-- 當struts的配置檔案修改後,系統是否自動重新載入該檔案,預設值為false(生產環境下使用),開發階段最好開啟 -->
<constant name="struts.configuration.xml.reload" value="true" />
<!-- 開發模式下使用,這樣可以打印出更詳細的錯誤資訊 -->
<constant name="struts.devMode" value="true" />
<!-- 預設的檢視主題 -->
<constant name="struts.ui.theme" value="simple" />
<!-- spring 託管 -->
<constant name="struts.objectFactory" value="spring" />
<!--
指定載入struts2配置檔案管理器,預設為org.apache.struts2.config.DefaultConfiguration
開發者可以自定義配置檔案管理器,該類要實現Configuration介面,可以自動載入struts2配置檔案。
-->
<constant name="struts.configuration"
value="org.apache.struts2.config.DefaultConfiguration" />
<!-- 設定預設的locale和字元編碼 -->
<constant name="struts.locale" value="zh_CN" />
<constant name="struts.i18n.encoding" value="GBK" />
<!-- 指定Struts的工廠類 -->
<constant name="struts.objectFactory" value="spring"></constant>
<!--
指定spring框架的裝配模式,裝配方式有: name, type, auto, and constructor (name
是預設裝配模式)
-->
<constant name="struts.objectFactory.spring.autoWire" value="name" />
<!-- 該屬性指定整合spring時,是否對bean進行快取,值為true or false,預設為true -->
<cosntant name="struts.objectFactory.spring.useClassCache" />
<!-- 指定型別檢查,包含tiger和notiger -->
<cosntant name="struts.objectTypeDeterminer" value="tiger" />
<!-- 該屬性指定處理 MIME-type multipart/form-data,檔案上傳 -->
<constant name="struts.multipart.parser" value="cos" />
<constant name="struts.multipart.parser" value="pell" />
<constant name="struts.multipart.parser" value="jakarta" />
<!-- 指定上傳檔案時的臨時目錄,預設使用 javax.servlet.context.tempdir -->
<constant name="struts.multipart.saveDir" value="/tmpuploadfiles" />
<!-- 該屬性指定Struts 2檔案上傳中整個請求內容允許的最大位元組數 -->
<constant name="struts.multipart.maxSize" value="2097152" />
<!--
該屬性指定Struts2應用載入使用者自定義的屬性檔案,該自定義屬性檔案指定的屬性不會覆蓋
struts.properties檔案中指定的屬性。如果需要載入多個自定義屬性檔案,多個自定義屬性文
件的檔名以英文逗號(,)隔開。(也就是說不要改寫struts.properties!)
-->
<constant name="struts.custom.properties"
value="application,org/apache/struts2/extension/custom" />
<!-- 指定請求url與action對映器,預設為org.apache.struts2.dispatcher.mapper.DefaultActionMapper -->
<constant name="struts.mapper.class" value="org.apache.struts2.dispatcher.mapper.DefaultActionMapper" />
<!-- 指定action的字尾,預設為action -->
<constant name="struts.action.extension" value="do" />
<!-- 被 FilterDispatcher使用指定瀏覽器是否快取靜態內容,測試階段設定為false,釋出階段設定為true. -->
<constant name="struts.serve.static.browserCache" value="true" />
<!-- 設定是否支援動態方法呼叫,true為支援,false不支援. -->
<constant name="struts.enable.DynamicMethodInvocation" value="true" />
<!-- 設定是否可以在action中使用斜線,預設為false不可以,想使用需設定為true. -->
<constant name="struts.enable.SlashesInActionNames" value="true" />
<!-- 是否允許使用表示式語法,預設為true. -->
<constant name="struts.tag.altSyntax" value="true" />
<!-- 設定當struts.xml檔案改動時,是否重新載入 -->
<cosntant name="struts.configuration.xml.reload" value="true" />
<!-- 設定struts是否為開發模式,預設為false,測試階段一般設為true. -->
<cosntant name="struts.devMode" value="true" />
<!-- 設定是否每次請求,都重新載入資原始檔,預設值為false. -->
<cosntant name="struts.i18n.reload" value="false" />
<!-- 標準的UI主題,預設的UI主題為xhtml,可以為simple,xhtml或ajax -->
<cosntant name="struts.ui.theme" value="xhtml" />
<!-- 模板目錄 -->
<cosntant name="struts.ui.templateDir" value="template" />
<!-- 設定模板型別. 可以為 ftl, vm, or jsp -->
<cosntant name="struts.ui.templateSuffix" value="ftl" />
<!-- 定位velocity.properties 檔案. 預設velocity.properties -->
<cosntant name="struts.velocity.configfile" value="velocity.properties" />
<!-- 設定velocity的context. -->
<cosntant name="struts.velocity.contexts" value="...." />
<!-- 定位toolbox -->
<cosntant name="struts.velocity.toolboxlocation" value="...." />
<!-- 指定web應用的埠 -->
<cosntant name="struts.url.http.port" value="80" />
<!-- 指定加密埠 -->
<cosntant name="struts.url.https.port" value="443" />
<!-- 設定生成url時,是否包含引數.值可以為: none,get or all -->
<cosntant name="struts.url.includeParams" value="get" />
<!-- 設定要載入的國際化資原始檔,以逗號分隔. -->
<cosntant name="struts.custom.i18n.resources" value="application" />
<!-- 對於一些web應用伺服器不能處理HttpServletRequest.getParameterMap(),
像 WebLogic,Orion, and OC4J等,須設定成true,預設為false. -->
<cosntant name="struts.dispatcher.parametersWorkaround" value="false" />
<!-- 指定freemarker管理器 -->
<cosntant name="struts.freemarker.manager.classname" value="org.apache.struts2.views.freemarker.FreemarkerManager" />
<!-- 設定是否對freemarker的模板設定快取,效果相當於把template拷貝到 WEB_APP/templates. -->
<cosntant name="struts.freemarker.templatesCache" value="false" />
<!-- 通常不需要修改此屬性. -->
<cosntant name="struts.freemarker.wrapper.altMap" value="true" />
<!-- 指定xslt result是否使用樣式表快取.開發階段設為true,釋出階段設為false. -->
<cosntant name="struts.xslt.nocache" value="false" />
<!-- 設定struts自動載入的檔案列表. -->
<cosntant name="struts.configuration.files" value="struts-default.xml,struts-plugin.xml,struts.xml" />
<!-- 設定是否一直在最後一個slash之前的任何位置選定namespace. -->
<cosntant name="struts.mapper.alwaysSelectFullNamespace" value="false" />
</struts>