一、配置web.xml
<filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
<init-param>
<param-name>actionPackages</param-name>
<param-value>com.test.action</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
二、加入注解
@Namespace(value="/test")
@Action(value = "file-manager",
interceptorRefs = {
@InterceptorRef(value = "fileUpload",params={"maximumSize","1024000","allowedTypes","image/pjpeg"}),
@InterceptorRef(value = "basicStack")},
results = {@Result(name = ActionSupport.SUCCESS, location = "/view/file-manager-sucess.jsp"),
@Result(name = ActionSupport.ERROR, location = "/view/file-manager-error.jsp") },
exceptionMappings = {@ExceptionMapping(exception = "java.lang.Exception", result = ActionSupport.ERROR)}
)
驗證注解:
@Validations(
requiredStrings={
@RequiredStringValidator(fieldName="username",message="用戶(hù)名不能為空!"),
@RequiredStringValidator(fieldName="telNum",message="電話(huà)號碼不能為空!")
},
regexFields={@RegexFieldValidator(fieldName="telNum",expression="^(\\+86|0|1)\\d{10,11}$",
message="電話(huà)號碼格式不正確!")}
)
跳過(guò)驗證注解:
@SkipValidation
三、Convention的Annotation
1)與Action相關(guān)的兩個(gè)Annotation是@Action 和@Actions
2)@Action中可指定一個(gè)value屬性。類(lèi)似于指定<action name=””/>屬性值
3)@Action中還可以指定一個(gè)params屬性,該屬性是一個(gè)字符串數組,用于該Acion指定的參數名和參數值。params屬性應遵守如下格式:{“name1”,”value1”,”name2”,”value2”}
4)@Actions 也用于修飾Action類(lèi)里的方法,用于將該方法映射到多個(gè)URL.@Actions用于組織多個(gè)@Action.因此它可將一個(gè)方法映射成多個(gè)邏輯Action。
四、與Result配置相關(guān)的Annotation
1)@ResultPath @Result 和Results
2)@Results用于組織多個(gè)@Result因此它只需指定一個(gè)value屬性值,該value屬性值為多個(gè)@Result
3)@Result相當于struts.xml文件中的<result/>元素。使用@Result必須指定一個(gè)name屬性,相當于<result name=””/>另外,它還有幾個(gè)可選的屬性。
☆ type 相當于<result type=””/>指定返回視圖資源的類(lèi)型
☆ location 相當于<result>…..</result>中間部分,用于指定實(shí)際視圖位置
☆ params:該屬性相當于<result/>元素里多個(gè)<param../>子元素的作用,用于為該Result指定參數值。該屬性應滿(mǎn)足{“name1”,”value1”,”name2”,”value2”}格式
4)@Result有以下兩種用法
1.Action級的Result映射:以@Actions組合多個(gè)@Action后修飾的Action類(lèi)。這種Result映射對該Action里的所有方法都有效。
2.方法級Result映射:將多個(gè)@Result組成數組后作為@Action的results屬性值。這種Result映射僅對被修飾的方法有效。
5)@ResultPath則用于修飾包和Action類(lèi),用于改變被修飾Action所對應的物理視圖資源的根路徑。舉例說(shuō):默認情況下,Convention都會(huì )到WEB-INF/content路徑下找物理視圖資源,一旦我們使用@ResultPath("/view")修飾該Action,系統將回到view目錄下尋找物理視圖資源。
五、與包和命名空間相關(guān)的Annotation:
@Namespace:修飾Action類(lèi)或其所在的包。該Annotation中指定一個(gè)value屬性值,用于指定被修飾的Action所在的命名空間
@Namespaces:修飾Action類(lèi)或其所在的包,用于組合多個(gè)@Namespace
@ParentPackage: 用于指定被修飾的Action所在包的父包。
六、與異常處理相關(guān)的Annotation
@ExceptionMappings 用于組織多個(gè)@ExceptionMapping,因此它只需指定一個(gè)value屬性值,該value屬性值為多個(gè)@ExceptionMapping。
@ExceptionMapping 用于定義異常類(lèi)和物理視圖之間的對應關(guān)系,也相當于struts.xml文件里<exception-mapping../>元素的作用 使用時(shí),必須注意以下兩個(gè)屬性:
exception: 用于指定異常類(lèi)
result:用于指定邏輯視圖
@ExceptionMpping有如下兩種用法
Action級的異常定義:以@ExceptionMappings組合多個(gè)@ExceptionMapping后修飾的Action類(lèi)。這種異常定義對Action中的所有方法有效
方法級的異常定義:將多個(gè)@ExceptionMapping組成數組后作為@Action的exceptionMappings屬性值,這種異常定義僅對被修飾的方法有效。
七、與攔截器配置相關(guān)的Annotation
與攔截器配置的Annotation有@InterceptorRef、@InterceptorRefs和@DefaultInterceptorRef
@InterceptorRefs用于組織多個(gè)@InterceptorRef,因此它只需要指定一個(gè)value屬性值,該value屬性值為多個(gè)@InterceptorRef
@InterceptorRef用于為指定Action引用lanjieq或者是攔截器棧。也就相當于strut.xml中位于<action../>元素內部的<interceptor-ref../>子元素的作用。使用@InterceptorRefAnnotation時(shí),必須制定一個(gè)value屬性,用于指定所引用的攔截器或攔截器棧的名字。相當于<interceptor-ref../>子元素里name屬性的作用。
八、查看struts2配置
為了看到struts2應用里的Action等各種資源的影射情況,struts2提供了Config Browser插件。
使用方法:將struts2-config-browser-plugin-2.1.6.jar文件復制到struts2應用的WEB-INF\lib目錄中。
打開(kāi)首頁(yè)地址:http://localhost:8080/應用名字/config-browser/actionNames.action 這里可以看到Config Browser插件的首頁(yè)。
本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請
點(diǎn)擊舉報。