第一篇:struts2根據struts2完全學習手冊 自己總結
一、struts2簡介 struts2的配置文件:
(1)struts.xml 配置示例:
“-//Apache Software Foundation//DTD Struts Configuration 2.0//EN”
“http://struts.apache.org/dtds/struts-2.0.dtd”>
HelloWorld
/example
(2)struts.properties配置文件 # # $Id: struts.properties 722328 2008-12-02 01:56:24Z davenewton $ # # Licensed to the Apache Software Foundation(ASF)under one # or more contributor license agreements.See the NOTICE file # distributed with this work for additional information # regarding copyright ownership.The ASF licenses this file # to you under the Apache License, Version 2.0(the # “License”);you may not use this file except in compliance # with the License.You may obtain a copy of the License at # # http://
struts2控制器
(1)核心控制器: FilterDispatcher(在web應用中負責攔截所有的用戶請求)
如果用戶的請求以.ation結尾,則該請求被轉入struts2框架處理。
(2)業務控制器: Action(在struts2中起作用的實際上不是用戶自定義的Action,而是系統自動生成的action代理,但該代理是以用戶自定義的action為目標的)Action 舉例:
package com.user.action;
public class Login {
} 由以上代碼可知:struts2中的action完全是普通的java類。Struts2中action接口不是必須實現的,任何包含有execute()方法的pojo(plain ordinary java object)private String userName;private String password;public String getUserName(){ } public void setUserName(String userName){ } public String getPassword(){ } public void setPassword(String password){ }
public String excute(){
} if(“admin”.equals(userName)&&(“password”.equals(password))){
} return “success”;return “error”;}else{ this.password = password;return password;this.userName = userName;return userName;對象都可以作為struts2的action對象。struts2標簽庫
<%@ page language=“java” import=“java.util.*” pageEncoding=“gbk”%> <%@ taglib prefix=“s” uri=“/struts-tags”%>(引入struts標簽)
通訊錄
第二篇:struts2面試題(自己總結)
Struts2面試題
1、struts2工作流程
Struts 2框架本身大致可以分為3個部分:
核心控制器FilterDispatcher、業務控制器Action和用戶實現的企業業務邏輯組件。
核心控制器FilterDispatcher是Struts 2框架的基礎,包含了框架內部的控制流程和處理機制。
業務控制器Action和業務邏輯組件是需要用戶來自己實現的。
用戶在開發Action和業務邏輯組件的同時,還需要編寫相關的配置文件,供核心控制器FilterDispatcher來使用。
Struts 2的工作流程相對于Struts 1要簡單,與WebWork框架基本相同,所以說Struts 2是WebWork的升級版本。基本簡要流程如下: 1、客戶端初始化一個指向Servlet容器的請求;
2、這個請求經過一系列的過濾器(Filter)
(這些過濾器中有一個叫做ActionContextCleanUp的可選過濾器,這個過濾器對于Struts2和其他框架的集成很有幫助,例如:SiteMesh Plugin)3、接著FilterDispatcher被調用,FilterDispatcher詢問ActionMapper來決定這個請是否需要調用某個Action
4、如果ActionMapper決定需要調用某個Action,FilterDispatcher把請求的處理交給ActionProxy
5、ActionProxy通過Configuration Manager詢問框架的配置文件,找到需要調用的Action類
6、ActionProxy創建一個ActionInvocation的實例。
7、ActionInvocation實例使用命名模式來調用,在調用Action的過程前后,涉及到相關攔截器(Intercepter)的調用。
8、一旦Action執行完畢,ActionInvocation負責根據struts.xml中的配置找到對應的返回結果。返回結果通常是(但不總是,也可 能是另外的一個Action鏈)一個需要被表示的JSP或者FreeMarker的模版。在表示的過程中可以使用Struts2 框架中繼承的標簽。在這個過程中需要涉及到ActionMapper
9、響應的返回是通過我們在web.xml中配置的過濾器
10、如果ActionContextCleanUp是當前使用的,則FilterDispatecher將不會清理sreadlocal ActionContext;如果ActionContextCleanUp不使用,則將會去清理sreadlocals。
2、說下Struts的設計模式
MVC模式: web應用程序啟動時就會加載并初始化ActionServler。用戶提交表單時,一個配置好的ActionForm對象被創建,并被填入表單相應的數據,ActionServler根據Struts-config.xml文件配置好的設置決定是否需要表單驗證,如果需要就調用ActionForm的Validate()驗證后選擇將請求發送到哪個Action,如果Action不存在,ActionServlet會先創建這個對象,然后調用Action的execute()方法。Execute()從ActionForm對象中獲取數據,完成業務邏輯,返回一個ActionForward對象,ActionServlet再把客戶請求轉發給ActionForward對象指定的jsp組件,ActionForward對象指定的jsp生 成動態的網頁,返回給客戶。
3、攔截器和過濾器的區別
1、攔截器是基于java反射機制的,而過濾器是基于函數回調的。
2、過濾器依賴于servlet容器,而攔截器不依賴于servlet容器。
3、攔截器只能對Action請求起作用,而過濾器則可以對幾乎所有請求起作用。
4、攔截器可以訪問Action上下文、值棧里的對象,而過濾器不能。
5、在Action的生命周期中,攔截器可以多次調用,而過濾器只能在容器初始化時被調用一次。
4、struts1于struts2的比較
1、Action 類: Struts1要求Action類繼承一個抽象基類。Struts1的一個普遍問題是使用抽象類編程而不是接口。
Struts 2 Action類可以實現一個Action接口,也可實現其他接口,使可選和定制的服務成為可能。Struts2提供一個ActionSupport基類去 實現常用的接口。Action接口不是必須的,任何有execute標識的POJO對象都可以用作Struts2的Action對象。
2、線程模式: Struts1 Action是單例模式并且必須是線程安全的,因為僅有Action的一個實例來處理所有的請求。單例策略限制了Struts1 Action能作的事,并且要在開發時特別小心。Action資源必須是線程安全的或同步的。
Struts2 Action對象為每一個請求產生一個實例,因此沒有線程安全問題。(實際上,servlet容器給每個請求產生許多可丟棄的對象,并且不會導致性能和垃圾回收問題)
3、Servlet 依賴: Struts1 Action 依賴于Servlet API ,因為當一個Action被調用時HttpServletRequest 和
HttpServletResponse 被傳遞給execute方法。
Struts 2 Action不依賴于容器,允許Action脫離容器單獨被測試。如果需要,Struts2 Action仍然可以訪問初始的request和response。但是,其他的元素減少或者消除了直接訪問HttpServetRequest 和
HttpServletResponse的必要性。
4、可測性:
測試Struts1 Action的一個主要問題是execute方法暴露了servlet API(這使得測試要依賴于容器)。一個第三方擴展--Struts TestCase--提供了一套Struts1的模擬對象(來進行測試)。
Struts 2 Action可以通過初始化、設置屬性、調用方法來測試,“依賴注入”支持也使測試更容易。
5、捕獲輸入:
Struts1 使用ActionForm對象捕獲輸入。所有的ActionForm必須繼承一個基類。因為其他JavaBean不能用作ActionForm,開發者經 常創建多余的類捕獲輸入。動態Bean(DynaBeans)可以作為創建傳統ActionForm的選擇,但是,開發者可能是在重新描述(創建)已經存 在的JavaBean(仍然會導致有冗余的javabean)。
Struts 2直接使用Action屬性作為輸入屬性,消除了對第二個輸入對象的需求。輸入屬性可能是有自己(子)屬性的rich對象類型。Action屬性能夠通過
web頁面上的taglibs訪問。Struts2也支持ActionForm模式。rich對象類型,包括業務對象,能夠用作輸入/輸出對象。這種
ModelDriven 特性簡化了taglib對POJO輸入對象的引用。
6、表達式語言:
Struts1 整合了JSTL,因此使用JSTL EL。這種EL有基本對象圖遍歷,但是對集合和索引屬性的支持很弱。
Struts2可以使用JSTL,但是也支持一個更強大和靈活的表達式語言-- “Object Graph Notation Language ”(OGNL).7、綁定值到頁面(view): Struts 1使用標準JSP機制把對象綁定到頁面中來訪問。
Struts 2 使用
“ValueStack ”技術,使taglib能夠訪問值而不需要把你的頁面(view)和對象綁定起來。ValueStack策略允許通過一系列名稱相同但類型不同的屬性重用頁面(view)。
8、類型轉換:
Struts 1 ActionForm 屬性通常都是String類型。Struts1使用Commons-Beanutils進行類型轉換。每個類一個轉換器,對每一個實例來說是不可配置的。
Struts2 使用OGNL進行類型轉換。提供基本和常用對象的轉換器。
9、校驗:
Struts 1支持在ActionForm的validate方法中手動校驗,或者通過Commons Validator的擴展來校驗。同一個類可以有不同的校驗內容,但不能校驗子對象。
Struts2支持通過validate方法和XWork校驗框架來進行校驗。XWork校驗框架使用為屬性類類型定義的校驗和內容校驗,來支持chain校驗子屬性
10、Action執行的控制:
Struts1支持每一個模塊有單獨的Request Processors(生命周期),但是模塊中的所有Action必須共享相同的生命周期。
Struts2支持通過攔截器堆棧(Interceptor Stacks)為每一個Action創建不同的生命周期。堆棧能夠根據需要和不同的Action一起使用。
為什么要使用Struts2 Struts2 是一個相當強大的Java Web開源框架,是一個基于POJO的Action的MVC Web框架。它基于當年的Webwork和XWork框架,繼承其優點,同時做了相當的改進。
1.Struts2基于MVC架構,框架結構清晰,開發流程一目了然,開發人員可以很好的掌控開發的過程。
2使用OGNL進行參數傳遞。
OGNL提供了在Struts2里訪問各種作用域中的數據的簡單方式,你可以方便的獲取Request,Attribute,Application,Session,Parameters中的數據。大大簡化了開發人員在獲取這些數據時的代碼量。3強大的攔截器
Struts2 的攔截器是一個Action級別的AOP,Struts2中的許多特性都是通過攔截器來實現的,例如異常處理,文件上傳,驗證等。攔截器是可配置與重用的,可以將一些通用的功能如:登錄驗證,權限驗證等置于攔截器中以完成一些Java Web項目中比較通用的功能。在我實現的的一Web項目中,就是使用Struts2的攔截器來完成了系統中的權限驗證功能。4易于測試
Struts2的Action都是簡單的POJO,這樣可以方便的對Struts2的Action編寫測試用例,大大方便了5Java Web項目的測試。
易于擴展的插件機制在Struts2添加擴展是一件愉快而輕松的事情,只需要將所需要的Jar包放到WEB-INF/lib文件夾中,在struts.xml中作一些簡單的設置就可以實現擴展。6模塊化管理
Struts2已經把模塊化作為了體系架構中的基本思想,可以通過三種方法來將應用程序模塊化:將配置信息拆分成多個文件把自包含的應用模塊創建為插件創建新的框架特性,即將與特定應用無關的新功能組織成插件,以添加到多個應用中去。
7全局結果與聲明式異常
為應用程序添加全局的Result,和在配置文件中對異常進行處理,這樣當處理過程中出現指定異常時,可以跳轉到特定頁面。
他的如此之多的優點,是很多人比較的青睞,與spring ,Hibernate進行結合,組成了現在比較流行的ssh框架,當然每個公司都要自己的框架,也是ssh變異的產品。
struts2有哪些優點?
1)在軟件設計上Struts2的應用可以不依賴于Servlet API和struts API。Struts2的這種設計屬于無侵入式設計; 2)攔截器,實現如參數攔截注入等功能;
3)類型轉換器,可以把特殊的請求參數轉換成需要的類型; 4)多種表現層技術,如:JSP、freeMarker、Velocity等; 5)Struts2的輸入校驗可以對指定某個方法進行校驗;
6)提供了全局范圍、包范圍和Action范圍的國際化資源文件管理實現
struts2是如何啟動的?
struts2框架是通過Filter啟動的,即StrutsPrepareAndExecuteFilter,此過濾器為struts2的核心過濾器; StrutsPrepareAndExecuteFilter的init()方法中將會讀取類路徑下默認的配置文件struts.xml完成初始化操作。struts2讀取到struts.xml的內容后,是將內容封裝進javabean對象然后存放在內存中,以后用戶的每次請求處理將使用內存中的數據,而不是每次請求都讀取struts.xml文件。
struts2框架的核心控制器是什么?它有什么作用?
1)Struts2框架的核心控制器是StrutsPrepareAndExecuteFilter。2)作用:
負責攔截由
可以通過常量“struts.action.extension”修改action的后綴,如:
如果用戶需要指定多個請求后綴,則多個后綴之間以英文逗號(,)隔開。
struts2配置文件的加載順序?
struts.xml ——> struts.properties 常量可以在struts.xml或struts.properties中配置,如果在多個文件中配置了同一個常量,則后一個文件中配置的常量值會覆蓋前面文件中配置的常量值.struts.xml文件的作用:通知Struts2框架加載對應的Action資源
struts2常量的修改方式?
常量可以在struts.xml或struts.properties中配置,兩種配置方式如下: 1)在struts.xml文件中配置常量
struts.action.extension=do struts2如何訪問HttpServletRequest、HttpSession、ServletContext三個域對象?
方案一:
HttpServletRequest request =ServletActionContext.getRequest();HttpServletResponse response =ServletActionContext.getResponse();HttpSession session= request.getSession();ServletContext servletContext=ServletActionContext.getServletContext();
方案二:
類 implements ServletRequestAware,ServletResponseAware,SessionAware,ServletContextAware 注意:框架自動傳入對應的域對象
struts2是如何管理action的?這種管理方式有什么好處?
struts2框架中使用包來管理Action,包的作用和java中的類包是非常類似的。
主要用于管理一組業務功能相關的action。在實際應用中,我們應該把一組業務功能相關的Action放在同一個包下。
struts2中的默認包struts-default有什么作用?
1)struts-default包是由struts內置的,它定義了struts2內部的眾多攔截器和Result類型,而Struts2很多核心的功能都是通過這些內置的攔截器實現,如:從請求中
把請求參數封裝到action、文件上傳和數據驗證等等都是通過攔截器實現的。當包繼承了struts-default包才能使用struts2為我們提供的這些功能。2)struts-default包是在struts-default.xml中定義,struts-default.xml也是Struts2默認配置文件。Struts2每次都會自動加載 struts-default.xml文件。
3)通常每個包都應該繼承struts-default包。
struts2如何對指定的方法進行驗證?
1)validate()方法會校驗action中所有與execute方法簽名相同的方法; 2)要校驗指定的方法通過重寫validateXxx()方法實現,validateXxx()只會校驗action中方法名為Xxx的方法。其中Xxx的第一個字母要大寫; 3)當某個數據校驗失敗時,調用addFieldError()方法往系統的fieldErrors添加校驗失敗信息(為了使用addFieldError()方法,action可以繼承ActionSupport),如果系統 的fieldErrors包含失敗信息,struts2會將請求轉發到名為input的result;
4)在input視圖中可以通過
struts2默認能解決get和post提交方式的亂碼問題嗎?
不能。struts.i18n.encoding=UTF-8屬性值只能解析POST提交下的亂碼問題。
請你寫出struts2中至少5個的默認攔截器?
fileUpload 提供文件上傳功能
i18n 記錄用戶選擇的locale cookies 使用配置的name,value來是指cookies checkbox 添加了checkbox自動處理代碼,將沒有選中的checkbox的內容設定為false,而html默認情況下不提交沒有選中的checkbox。
chain 讓前一個Action的屬性可以被后一個Action訪問,現在和chain類型的result()結合使用。
alias 在不同請求之間將請求參數在不同名字件轉換,請求內容不變
值棧ValueStack的原理與生命周期?
1)ValueStack貫穿整個 Action 的生命周期,保存在request域中,所以ValueStack和request的生命周期一樣。當Struts2接受一個請求時,會迅速創建ActionContext,ValueStack,action。然后把action存放進ValueStack,所以action的實例變量可以被OGNL訪問。請求來的時候,action、ValueStack的生命開始,請求結束,action、ValueStack的生命結束;
2)action是多例的,和Servlet不一樣,Servelt是單例的;
3)每個action的都有一個對應的值棧,值棧存放的數據類型是該action的實例,以及該action中的實例變量,Action對象默認保存在棧頂; 4)ValueStack本質上就是一個ArrayList;
5)關于ContextMap,Struts 會把下面這些映射壓入 ContextMap 中: parameters : 該 Map 中包含當前請求的請求參數
request : 該 Map 中包含當前 request 對象中的所有屬性 session :該 Map 中包含當前 session 對象中的所有屬性
application :該 Map 中包含當前 application 對象中的所有屬性 attr:該 Map 按如下順序來檢索某個屬性: request, session, application 6)使用OGNL訪問值棧的內容時,不需要#號,而訪問request、session、application、attr時,需要加#號;
7)注意: Struts2中,OGNL表達式需要配合Struts標簽才可以使用。如:
ActionContext、ServletContext、pageContext的區別?
1)ActionContext是當前的Action的上下文環境,通過ActionContext可以獲取到request、session、ServletContext等與Action有關的對象的引用; 2)ServletContext是域對象,一個web應用中只有一個ServletContext,生命周期伴隨整個web應用;
3)pageContext是JSP中的最重要的一個內置對象,可以通過pageContext獲取其他域對象的應用,同時它是一個域對象,作用范圍只針對當前頁面,當前頁面結束時,pageContext銷毀,生命周期是JSP四個域對象中最小的。
result的type屬性中有哪幾種結果類型?
一共10種:
dispatcher struts默認的結果類型,把控制權轉發給應用程序里的某個資源不能把控制權轉發給一個外部資源,若需要把控制權重定向到一個外部資源, 應該使用 redirect結果類型
redirect 把響應重定向到另一個資源(包括一個外部資源)redirectAction 把響應重定向到另一個 Action freemarker、velocity、chain、httpheader、xslt、plainText、stream
攔截器的生命周期與工作過程?
1)每個攔截器都是實現了Interceptor接口的 Java 類;
2)init(): 該方法將在攔截器被創建后立即被調用, 它在攔截器的生命周期內只被調用一次.可以在該方法中對相關資源進行必要的初始化;
3)intercept(ActionInvocation invocation): 每攔截一個動作請求, 該方法就會被調用一次; 4)destroy: 該方法將在攔截器被銷毀之前被調用, 它在攔截器的生命周期內也只被調用一次;
5)struts2中有內置了18個攔截器。
struts2如何完成文件的上傳?
1、JSP頁面:
1)JSP頁面的上傳文件的組件:
name=“xxx”的值必須一樣;
2)必須把表單的enctype屬性設置為:multipart/form-data; 3)表單的方法必須為post,因為post提交的數據在消息體中,而無大小限制。
2、對應的action:
1)在 Action 中新添加 3 個和文件上傳相關的屬性;
2)如果是上傳單個文件, uploadImage屬性的類型就是 java.io.File, 它代表被上傳的文件, 第二個和第三個屬性的類型是 String, 它們分別代表上傳文 件的文件名和文件類型,定義方式是分別是:
jsp頁面file組件的名稱+ContentType, jsp頁面file組件的名稱+FileName 3)如果上上傳多個文件, 可以使用數組或 List
第三篇:struts2知識總結
struts2知識總結
1.全局的邏輯控制器為一個過濾器,負責過濾所有的請求。該過濾器引用的API類為
org.apache.struts2.disapatcher.FilterDispatcher
2.MVC:頁面請求(jsp)——>邏輯控制器(Filter)——>業務控制器(Action)——>業務邏輯組件——>業務處理/DAO
3.struts2的配置文件放在classpath下。
4.struts2的類型轉換:
a.繼承DefaultTypeConverter,覆蓋父類的public Object convertValue(Map context, Object value, Class toType)方法
b.繼承StrutsTypeConverter, 覆蓋父類的public Object convertFromString(Map context, String[] values, Class toClass)該方法負責轉換從頁面傳遞過來的數據。
覆蓋父類的public String convertToString(Map context, Object o)
該方法負責將Action中處理好的數據轉換成相應格式的字符串。
5.struts2的數據驗證:
a.使用編碼方式進行驗證。業務控制器Action繼承ActionSupport類,重寫public void validate()方法。
在該方法中進行數據驗證。若Action中處理業務的方法為test,則可以編寫public void validateTest()方法,來對test方法的數據進行驗證。(系統在進行validateTest方法后,會接著執行validate方法,然后
才執行相應的業務代碼。)
若嚴重出錯,則可以調用addFieldError或者調用addActionError方法,增加相應的錯誤提示信息。
b.使用配置xml文件進行驗證。驗證文件的名字為:×××Action-validation.xml。驗證的方式包含字段驗證和非字段驗證。
其中字段驗證表示對某個字段進行某些類型的驗證。非字段驗證表示用某個類型的驗證來驗證,某個字段。兩種方式
底層實現一樣,只是表現方式不同,字段驗證方式比較直觀。
驗證的類型有一下幾種:required,requiredstring,int,date,double,expression,fieldexpression email,url,visitor,conversion,stringLength,regex(正則表達式)。
對驗證類型可以指定shourt-circuit參數為true,來執行短路驗證。
如果Action中執行業務的方法為test,則可以通過編寫×××Action-test-validation.xml方法來對test方法的數據進行 驗證。且執行完test方法的私有驗證文件后,還會執行默認的驗證文件×××Action-test-validation.xml的驗證。
c.struts2進行客戶端的驗證。首先需要使用struts2的標簽庫,且標簽庫的theme屬性不能為simple,然后設置標簽的validate屬性為true。
注意:struts2的客戶端驗證依賴于服務器的驗證配置文件。
6.struts2的攔截器。struts2的攔截器是struts2的核心,其底層實現使用了Java的反射機制與動態代理。在struts2的配置文件中
為一個Action引入了一個攔截器,則配置的默認攔截器不會被調用,需要手工配置到該Action中。
實現struts2攔截器的方法:
a.實現Interceptor接口,并實現init,destrory以及intercept方法。
b.繼承AbstractInterceptor類,覆蓋intercept方法。
c.繼承MethodFilterInterceptor類,覆蓋intercept方法。該類可以對特定的方法進行攔截。
攔截器棧可以包含攔截器和攔截器棧。
7.文件的上傳和下載:
a.使用apache組織開發的commons-fileupload和commons-io包,并且按需要配置fileUpload攔截器和相應的上傳參數,比如上傳文件的類型,上傳文件的大小。多文件的上傳可以使用js代碼來在頁面修改上傳文件的列表,在Action中
則用三個列表分別來保存文件對象(file),文件名(fileName),以及文件類型(fileContentType)。
b.文件下載使用流進行讀取:return ServletActionContext.getServletContext.getResourceAsStream(“文件名”)并將Action的結果返回類設定為stream,即流。按需要配置相應的參數。
8.struts2的國際化。struts2國際化的底層實現用到了Java基礎類庫中的Locale(地區)和ResourceBundle(消息資源)兩個類。
struts2的國際化主要用在一下幾個地方:
a.jsp頁面:使用struts2的標簽時,指定標簽的key屬性(對應消息資源文件中的key)。
使用
還可以用
b.Action中:調用getText(key)或者getText(key,args)方法取得消息資源文件中的消息資源。
c.xml驗證文件中:指定message元素的key屬性(對應消息資源文件中的key)。(怎么傳參數?)d.類型轉換過程中:通過查看xwork包的源代碼可以找到:ge.properties文件中可以找到如下的鍵值對:
xwork.default.invalid.fieldvalue=Invalid field value for field “{0}”.在消息資源文件中重新指定該鍵值對即可。
另外在struts.properties中設定鍵值對struts.i18n.encoding=GBK,可以解決中文亂碼問題。
9.struts2的異常處理。在Action中,我們的業務邏輯處理方法都對拋出異常進行了聲明。具體的異常對應具體的處理結果。
在action配置中:
還可以配置全局的異常處理:
struts2的其他東西:
1.對于struts.xml中的package:
a.設置
,則表明該包中沒有action的配置,只定義一個基礎公共的組件。
b.package的namespace可以將不同的請求路徑分隔開,在多人合作項目中用到比較多。當接收到一個請求,若在當前的namespace中沒有相應的請求地址,則會到默認的namespace中去尋找匹配的地址。
2.模型驅動機制(ModelDriven),將一個Action中的各個參數封裝成為一個JavaBean(類似struts1.x中的
ActionForm)。需要實現ModelDriven
3.防止表單的重復提交:在jsp的表單中設置
配置該key,來實現國際化。
4.struts2中Action與Servlet容器的耦合。主要有三種方式: a.實現ServletRequestAware或ServletResponseAware接口。并提供對request或者response熟悉的設置方法。
b.使用ActionContext(但不能獲得response對象)。改方法方便單元測試。
c.使用ServletActionContext。ServletActionContext是ActionContext的子類。
首選使用ActionContext,其次ServletActionContext。
5.整合多個struts配置文件,在struts2的配置文件中使用include元素包含其他的配置文件。用于多模塊開發。
6.可以在web.xml中對struts2的核心過濾器FilterDispatcher設置初始化參數(不推薦使用)。
7.動態方法調用(DynamicMethodInvocation).a.action配置中指定:
b.在客戶端即頁面指定:
c.使用通配符:
使得程序不明了,不提倡使用該方法。
8.struts2的結果類型。在struts2-core包中,有幾種struts2已經配置好的結果類型。
其中默認的類型為dispatcher,此外還有:redirectAction,chain,freemaker,httpheader,redirect, redirectAction,stream,velocity,xslt,plainText。
9.struts2與spring的整合。導入struts2-spring-plugin包,在web.xml中設置spring的監聽器, spring監聽器對應的API類為:org.springframework.web.context.ContextLoaderListener。
struts2-spring-plugin包為我們將struts2的對象工廠設置為spring的IoC容器,其代碼為:
很明顯,將struts.objectFactory定位為org.apache.struts2.spring.StrutsSpringObjectFactory 其余的工作就交給spring的IoC容器去做了。
另外:當我們需要增加spring的配置文件時,需要在web.xml中設定contextConfigLocation參數。代碼如下:
contextConfigLocation 其他的spring配置文件名,用逗號隔開
需要注意的一些地方
1.存儲fieldError的是一個LinkedHashMap
ActionSupport中的getFieldError方法返回的是一個新的集合。該集合是原fieldError集合的一個副本。
在struts2的源代碼中返回的是:new LinkedHashMap(internalGetFieldError),即一個新的集合對象。
所以執行代碼:this.getFieldErrors.put(”username“,”ErrorMsg");不會影響原fieldError集合的數據。
2.若一個Action注冊了PreResultListner,則會在該Action返回的時候調用相應結果驗證的邏輯代碼。
3.struts2-core包中的default.properties和struts-default.xml文件保存了一些struts2默認的配置。
可以在自己的struts配置文件中對相應的配置進行覆蓋或重新設值。比如修改請求的后綴名:在struts.properties 中加入:
struts.action.extension = do 則將struts2請求的后綴名修改成了struts1中的do后綴名的形式。
4.在配置文件中配置struts.multipart.saveDir來設定上傳文件時的臨時文件的存儲位置。需要定期清理該路徑下的文件。
第四篇:easyui結合struts2總結
easyui 結合Struts2 總結 在把struts2框架搭好以后,由于easyui和后臺交互主要是靠ajax來進行的并且返回的數據格式是json形式的。所以我們必須在項目中引入struts2-json-plugin 來方便的把數據轉換為json格式。需要的jar包如下圖:
下面是我寫的一個小例子,來更好的說明之間數據是如何傳遞的。(為了節省篇幅,數據庫表就省略了)jsp頁面主要代碼如下:
當我們把頁面寫好以后就要寫action類了。主要代碼如下:
get、set方法這里就省略了。
接下來就是在struts.xml 中進行配置了。代碼如下
這里要特別注意了,繼承的是json-default, result 中德type是json。這里的配置是關鍵,起初由于配置問題,花了我很多時間。然后就是寫EmpService類和getAll方法了。代碼如下
這里我是把對象先放到map集合中,讓和放到list集合中,這樣就自動轉為json格式(感覺有些麻煩,誰有好的方法,請發送到zl673170035@163.com,謝謝哈)然后在瀏覽器上運行。
在js 中加入了工具條。
剩下的修改、刪除、增加,我是仿照easyui官網的demo中的一個例子做的。我遇到的主要問題就是,ajax 如何把參數傳給action和ajax如何接收action傳回的參數。
首先說說第一個問題,ajax 如何把參數傳給action.。
只要action 中有相對應的get和set 方法。我們發起ajax請求時struts就自動的把參數加到action中了。
這里把參數名都變為emp.XX 然后在action 中加入成員變量emp和get、set方法。這樣action就能接收值了。
接下來需要從action中給ajax中傳遞參數了。我們在struts.xml中如下配置
在action中設置result 的get、set 方法。這樣ajax就能接收到action傳回的參數了。
好了這是我的一點心得,希望對你有用。
第五篇:Struts2核心攔截器---學習筆記
Struts2的核心——攔截器
在struts2中,攔截器(Interceptor)是其核心的組件,當我們訪問一個action時,我們可以通過攔截器的配置,做一些需要的操作。
我們可以寫我們自己的攔截器,但是要實現或繼承struts2給我們提供的接口或類。
①.我們實現Interceptor接口,該接口是struts2提供的攔截器接口,位于com.opensymphony.xwork2.interceptor包下,其提供了類似與filter的一些方法,我們必須實現它的方法:destroy()、init()、intercept(ActionInvocation)。
public class MyInterceptor implements Interceptor {
public void destroy(){
System.out.println(“destroy”);} public void init(){ } public String intercept(ActionInvocation invocation)throws System.out.println(“init”);Exception {
System.out.println(“intercept”);
String resultString= invocation.invoke();System.out.println(“finish”);return resultString;}
②.我們可以繼承AbstractInterceptor類,該類是一個抽象類,它位于com.opensymphony.xwork2.interceptor包下,它實現了Interceptor接口,并完成了對destroy()方法和init()方法的實現,但保留了抽象方法interceptor(),以供自定義的攔截器來重寫其方法,完成特定的需求。
public class MyInterceptor1 extends AbstractInterceptor {
} @Override
public String intercept(ActionInvocation invocation)throws
System.out.println(“intercept1”);
String result=invocation.invoke();
System.out.println(“finish1”);Exception { return result;}
③.上面兩個是對action進行的攔截,粒度比較粗,當然struts2也給我們提供了對action中方法的攔截。這時,我們自己寫的類就要繼承struts
2給我們提供的方法過濾類,該
類
同
樣
位
于MethodFilterInterceptor com.opensymphony.xwork2.interceptor包下,但該類已經完成了對interceptor()方法的簡單實現,而提供了一個doIntercept()方法。
public class MyInterceptor2 extends MethodFilterInterceptor { @Override
protected String doIntercept(ActionInvocation invocation)throws Exception {
System.out.println(“methodFilterInterceptor2”);String result=invocation.invoke();System.out.println(“finish2”);
return result;} }
寫好了我們自己的攔截器類,還需要在struts.xml文件進行配置來告訴struts2框架,我們的攔截器要攔截的action、方法。
首先,我們要在package包下增加一個新的元素標簽 class=“com.test.interceptor.MyInterceptor”>
定義了一個name是myInterceptor的攔截器(即實現了Interceptor接口的那個攔截器),類似的,我們定義了上面我們已寫的3個攔截器。
name=“myInterceptor” class=“com.test.interceptor.MyInterceptor”>
請注意下面代碼,我們定義了
name=“myInterceptor”>
name=“myInterceptor1”>
defaultStack這個攔截器棧是struts2,提供的一個默認攔截器棧,其中實現了一些常用功能,如:struts2的檢驗框架,當我們在聲明package時候會有extends屬性,其值為struts-default,而defaultStack就定義在struts-default包類,進而就被我們的package所繼承。
name=“defaultStack”>
在攔截器的配置中,我們可以為package配置一個默認的攔截器或攔截器棧,如果我們不指定,其值就為父包繼承下來的defaultStack。
name=“myStack”>
標簽,可以對攔截器類中定義的屬性賦值,這里是告訴攔截器,只攔截abc()方法。
abc