使用Convention插件,需要将其JAR文件放到你应用的WEB-INF/lib目录中,你也可以在你maven项目的POM文件中添加下面包依赖
- <dependency>
- <groupId>org.apache.struts</groupId>
- <artifactId>struts2-convention-plugin</artifactId>
- <version>2.1.6</version>
- </dependency
convention-plugin的约定
1.默认情况下,Convention会默认所有的结果页面都存储在WEB-INF/content下,你也可以在struts的配置文件中设定struts.convention.result.path的值到一个新的路径。如
- <constantname="struts.convention.result.path"value="/WEB-INF/page"/>
这样的话所有结果页面的会存储在WEB-INF/page下了,把jsp放在WEB-INF下有一个好处,别人就没有办法直接访问了,这样就可以简化spring security的配置工作。
2. 默认情况下,包的路径包含action,actions,struts,struts2的所有包都会被struts作为含有Action类的路径来搜索。你可以通过设置struts.convention.package.locators属性来修改这个配置,如springside的struts.xml中是这样配置的,
- <constantname="struts.convention.package.locators"value="web"/>
则在项目中,包的路径含有web的将被视为Action存在的路径来进行搜索。
3. 接着,Convention从前一步找到的package以及其子package中寻找com.opensymphony.xwork2.Action 的实现以及以Action结尾的类,如:
com.courseonline.test.web.account.UserAction 就会被扫描到。
4. 命名空间。从定义的.package.locators标示开始到包结束的部分,就是命名空间。举个例子,上面我们定义了
- <constantname="struts.convention.package.locators"value="web"/>
所以 com.courseonline.test.web.account.UserAction的命名空间是:“/account”。
5. Convention通过如下规则确定URL的具体资源部分:去掉类名的Action部分。然后将每个分部的首字母转为小写,用‘-’分割,你可以设置struts.convention.action.name.separator如
- <constantname="struts.convention.action.name.separator"value="-"/>
比如上面的例子com.courseonline.test.web.account.UserAction对应的jsp为/WEB-INF/content/account/use.jsp
如果是com.courseonline.test.web.account.UserDetailAction 对应的jsp为/WEB-INF/content/account/use-detail.jsp
下面是convention的一些常用注解
1.@Action 注解
- publicclassUserActionextendsActionSupport{
- @Action("url1")
- publicStringmethod1(){
- returnSUCCESS;
- }
- @Action("/account/url2")
- publicStringmethod2(){
- returnSUCCESS;
- }
- }
未用@Action注解前
默认调用路径 | 访问方法 | 默认映射路径 |
/user!method1.action | method1 | /WEB-INF/content/user.jsp |
/user!method2.action | method2 | /WEB-INF/content/user.jsp |
使用@Action注解后
@Action注解后调用的路径 | 访问方法 | @Action注解后映射的路径 |
/url1!method1.action | method1 | /WEB-INF/content/url1.jsp |
/account/url2!method2.action | method2 | /WEB-INF/content/account/url2.jsp |
2.@Namespace 注释
- @Namespace("/account")
- publicclassUserDetailActionextendsActionSupport{
- publicStringmethod1(){
- return"error";
- }
- @Action("url")
- publicStringmethod2(){
- return“error”;
- }
- @Action("/different/url2")
- publicStringmethod3(){
- return“error”;
- }
- }
调用路径 | 访问方法 | 映射路径 |
/account/user-detail!method1.acton | method1 | /WEN-INF/content/account/user-detail-error.jsp |
/account/url!method2.acton | method2 | /WEN-INF/content/account/url.jsp |
/different/url2!method3.action | method3 | /WEN-INF/content/different/url2.jsp |
与@Action 注释不同的是,该注释覆盖了默认的namespace(默认的是’/’),此时再用user-detail!method1.action 已经不能访问method1了.
3.@Result
Convention允许action类为每个action定义不同的results,results分为两类,全局的(global)和本地的(local),全局results可以被action类中所有的action分享,这种results在action类上使用注解进行声明。本地results只能在action方法上进行声明。下面是两种results注解的例子.
1)全局的(global)。
- @Results({@Result(name="failure",location="/WEB-INF/fail.jsp")})
- publicclassUserActionextendsActionSupport{
- Stringmethod1(){
- return“failure”;
- }
- @Action("/different/url")
- publicStringmethod2(){
- return“failure”;
- }
- }
调用路径 | 访问方法 | 映射路径 |
/user!method1.action | method1 | /WEB-INF/fail.jsp |
/different/url!method2.action | method2 | /WEB-INF/fail.jsp |
2 本地的(local)。
- publicclassUserActionextendsActionSupport{
- @Action(value="/other/url",results={@Result(name="error",location="/WEB-INF/fail",type="redirect")})
- publicStringmethod1(){
- return“error”;
- }
- }
调用路径 | 访问方法 | 映射路径 |
/user!method1.action | method1 | /WEB-INF/content/user-error.jsp |
/other/url!method2.action | method1 | /WEB-INF/fail.jsp |
有了上面的知识,现在来看看springside 3 的mini-web项目中部分用到的convention插件的地方,理解起来就不难了。
比较典型的是UserAction.java。
- @Namespace("/account")
- @Results({@Result(name=CrudActionSupport.RELOAD,location="user.action",type="redirect")})
- publicclassUserActionextendsCrudActionSupport<User>{
- ………………
- @Override
- publicStringlist()throwsException{
- …………
- returnSUCCESS;
- }
- @Override
- publicStringinput()throwsException{
- …………
- returnINPUT;
- }
- @Override
- publicStringsave()throwsException{
- …………
- returnRELOAD;
- }
- ………………
- }
这里我只选了三个返回结果分别为SUCCESS、INPUT、和RELOAD的方法来做例子。
调用路径 | 访问方法 | 映射路径 |
/account/user!list.action | list | /WEB-INF/content/account/user.jsp |
/account/user!input.action | input | /WEB-INF/content/account/user-input.jsp |
/account/user!save.action | save | /WEB-INF/content/account/user.jsp |
在调用save方法后,为什么会返回/WEB-INF/content/account/user.jsp这个页面 呢?因为在全局的Result定义名为reload的result重定向到user.action, 其他result则按照convention默认,所以当调用完save方法后,返回的是RELOAD,又被重定向到user.action,然后返回到/WEB-INF/content/account/user.jsp 了;同理,访问input方法时,返回的是INPUT,所以会返回/WEB-INF/content/account/user-input.jsp
@Namespace("/account") 表示定义URL映射对应/account/user.action
@Results( {@Result(name = CrudActionSupport.RELOAD, location = "user.action",type = "redirect") })
定义名为reload的result重定向到user.action,其他result则按照convention默认.
以上说的不一定都是正确的,如有错误请指正,谢谢。
参考资料:http://www.blogjava.net/libin2722/articles/256525.html
以上:blog.youkuaiyun.com/javaer617/article/details/6413055