零配置≠无配置

 零配置≠无配置
约定优于配置
Struts2-convention-plugin.jar位于struts2/lib目录下
 它提供基于annotation(注解)的方式来代替struts.xml
在该jar包下的struts-plugin.xml是对该插件的各种基本配置。它继承于struts-default。如果需要改变配置,可以在struts.xml中进行常量声明和赋值来替换默认配置
 常量说明(以下常量均为默认配置):
<!– 结果资源所在路径,也就是返回的页面路径 –>
<constant name=”struts.convention.result.path” value=”/WEB-INF/content/”/>

<!– 搜索的Action资源包路径,无论层级,例如package.action,多项以逗号隔开–>

<constant name=”struts.convention.package.locators” value=”action,actions,struts,struts2″/>

<!– 指定哪些包不搜索 –>

<constant name=”struts.convention.exclude.packages” value=”org.apache.struts.*”/>



<!– 是否将返回的字符串作为资源名的一部分,例如MyTestAction中方法返回“abc”,如果设为true,则视图资源名为         my-test-abc.jsp,false则为my-test.jsp –>

<constant name=”struts.convention.result.flatLayout” value=”true”/>



<!– 类名最后的组成部分,比如设置成qqq,则MyTestqqq将视为action,而MyTest则不是,访问时  会截去这个部分 –>

<constant name=”struts.convention.action.suffix” value=”Action”/>



<!– 是否不扫描类,默认false即要扫描,设为true则所有访问无效(不排除未知情况) –>

<constant name=”struts.convention.action.disableScanning” value=”false”/>



<!– 始终创建action映射,即使没有@Action被发现(具体情况不明) –>

<constant name=”struts.convention.action.mapAllMatches” value=”false”/>

<!– 是否检查类是不是实现了com.opensymphony.xwork2.Action接口,默认为true,即只要实现了此   接口的类为被视为     Action,设为false则不进行检查,无论是否实现都会无视 –>

<constant name=”struts.convention.action.checkImplementsAction” value=”true”/>

<!– 设置默认的父包 –>

<constant name=”struts.convention.default.parent.package” value=”convention-default”/>

<!– 是否将Action类名转换成小写,默认true,例如MyTest访问的url名为my-test,设为false,则    为My-Test –>

<constant name=”struts.convention.action.name.lowercase” value=”true”/>

<!– 名字分割符,即MyTest访问名为my-test,默认对应的页面为my-test-success.jsp –>

<constant name=”struts.convention.action.name.separator” value=”-”/>



<!– 是否禁用包扫描,对应struts.convention.package.locators设置 –>

<constant name=”struts.convention.package.locators.disable” value=”false”/>



<!– 设置包扫描的结构,默认为空,例如com.jd.web就只会扫描项目中此结构包下的 子包,忽略其他包 –>

<constant name=”struts.convention.package.locators.basePackage” value=”"/>



<!– 默认返回结果类型 –>

<constant name=”struts.convention.relative.result.types”value=”dispatcher,velocity,freemarker”/>



<!– 是否使用 / 作为重定向标示符,默认true,@Result(location=”/test.jsp”) 则会在server/项目名/这个路径下找test.jsp,     不加 / 则会在struts.convention.result.path这个常量配置的路径下找,若设为false则 / 无效–>

<constant name=”struts.convention.redirect.to.slash” value=”true”/>



<!– 不是很清楚,测试结果为:设置成false则报没有no action mapped,应该是默认是否执行execute()方法 –>

<constant name=”struts.convention.action.alwaysMapExecute” value=”true”/>



<!– 设定是否一直在最后一个斜线之前的任何位置选定namespace,测试结果为无任何影响,情况不明 –>

<constant name=”struts.mapper.alwaysSelectFullNamespace” value=”true”/>



<!– 官方只说明在jboss下需要设置,情况不明 –>
<constant name=”struts.convention.exclude.parentClassLoader” value=”true” />
<constant name=”struts.convention.action.fileProtocols” value=”jar” />
<!– 是否自动重新加载action –>
<constant name=”struts.convention.classes.reload” value=”false” />
 Annotation(注解)
@Action(String value)
用来代替类名的访问名,例如MyTest类,在类级别上@Action(“abc”),则访问的action名为abc,而不是默认的my-test,此注解也可写在方法上,定义为访问该方法的action名。此注解受struts.convention.redirect.to.slash影响。返回视图为abc.jsp,忽略方法返回的字符串。
@Actions
包含一个@Action数组
格式:@Action({@Action() , @Action()})

@Result
定义方法返回的结果类型,参数,资源路径,此注解必须写在类级别上。
格式:@Result(name=”" , location=”" , type=”" ,  params={“”,”"})
name对应方法返回的字符串,location对应返回资源的路径,type对应返回资源类型
params对应返回结果的参数,格式params={“key0″,”value0″,”"key1,”value1″….”keyN”,”valueN”}

@Results
包含一个@Result数组
格式:参照@Actions

@Namespace
指定action的访问路径,会替换掉默认package的路径。
格式:@Namespace(String value)
例如:假设MyTest默认Namespace为/test,其访问路径为xxx/test/my-test。若设置为@Namespace(“abc”),       则访问路径为/abc/my-test。

注意:默认情况下action的访问路径必须和返回视图资源路径对应。
例如:假设默认搜索xxx.xxxx.xxx.web包下的action,MyTest类在web.action.test包下,则MyTest类中   方法默认情况返回搜索视图的路径为/WEB-INF/content/action/test/xxx.jsp

关于映射路径感觉不适应的情况,struts2提供了一个插件,可以查看当前项目所有action的映射情况
将struts2/lib下的struts2-config-browser-plugin加入到项目的lib目录下,启动项目,url输入 http://localhost:port/项目名/config-browser/index.action。


你可能感兴趣的:(零配置≠无配置)