**struts2 之 action**
开发中实现action的方法,一般只用这种方法:
struts2页面中一般都是用绝对路径
在页面中添加如下代码
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
然后在写路径是使用这样的格式 <a href="<%=basePath%>index.jsp"/>
或者
在head标签中添加base标签 <base href="<%=basePath%>"/> 这样在所有路径中会自动将basePath加到路径前面
动态调用acton方法,常用 !符号
例如连接中这样写...../ userAction!execute
通配符调用action *可以是任何字符
<action name="Student*" class="com.bjsxt.struts2.action.StudentAction" method="{1}">//{1}表示第一个*的字符添加到这里
<result>/Student{1}_success.jsp</result>
</action>
!!使用通配符 可是使配置文件比较简单
例如:
<action name="*_*" class="com.bjsxt.struts2.action.{1}Action" method="{2}">
<result>/{1}_{2}_success.jsp</result>
</action>
约定优于配置
类名,方法,result页面名称,约定好的话,struts配置文件会很简单!
action中接收页面传递的参数的方式:
1>在action中 设置同名的属性,并添加set get方法,struts会自动接收并赋值,以setXXX(), getXXXX() 方法中XXXX的名称为准.
2>使用domain model 域模型 在问题域中实际存在的模型
在jsp页面中
<a href="user/user!add?user.name=a&user.age=8">
当页面传递的参数与域模型,实体模型的属性不一一对应时,应当使用vo/do/dto模型接收页面传递的参数,处理之后根据这些模型生成实体类对象.
这里的vo/do/dto 只起到了数据传递的作用
3>模型驱动方式 ModelDriven action类implement ModelDriven<model class 例如:User>
action类中实现 public <model class> getModel()方法 { return user//这个名与action中的model类对象名相同}
源代码:
**struts 传递参数是中文乱码问题的解决
<struts>
<constant name="struts.devMode" value="true" />
<constant name="struts.i18n.encoding" value="GBK" /> <!-- internationalization -->
<package name="user" extends="struts-default" namespace="/user">
<action name="userAdd" class="com.bjsxt.struts2.user.action.UserAction" method="add">
<result>/user_add_success.jsp</result>
</action>
<action name="user" class="com.bjsxt.struts2.user.action.UserAction">
<result>/user_add_success.jsp</result>
</action>
</package>
</struts>
简单数据校验
public String add() {
if(name == null || !name.equals("admin")) {
this.addFieldError("name", "name is error");
this.addFieldError("name", "name is too long");
return ERROR;
}
return SUCCESS;
}
错误页面:
<body>
User Add Error!
<s:fielderror fieldName="name" theme="simple"/>
<br />
<s:property value="errors.name[0]"/>
<s:debug></s:debug>
</body>
在action中得到访问web元素的request,session,application对象最常用的方式
默认的action
<struts>
<constant name="struts.devMode" value="true" />
<package name="default" namespace="/" extends="struts-default">
<default-action-ref name="index"></default-action-ref>
<action name="index">
<result>/default.jsp</result>
</action>
</package>
</struts>
##Action总结##
1.实现action的最常用方式:从ActionSupport继承
2.DMI动态方法调用
3.通配符配置*_* {1}_{2}
4.接收参数的方法(!!一般使用action属性或者DomainModel来接收)
5.简单参数验证 addFieldErrro()方法
**一般不使用Struts2的UI标签,无法灵活处理错误信息
6.访问wed元素
7.包含文件配置 xml中 included 属性
8。默认action处理 struts.xml
*<default-action-ref name="actionName1">
即当无法找到对应的action时,执行actinName1这个action
**Struts2 之 Result**
Result的种类及使用:
<package name="resultTypes" namespace="/r" extends="struts-default">
<action name="r1">
<result type="dispatcher">/r1.jsp</result>//默认选项,为服务器端跳转,只能跳到html,jsp页面,不能跳到action
</action>
<action name="r2">
<result type="redirect">/r2.jsp</result>//客户端跳转,只能跳到视图,不能action
</action>
<action name="r3">
<result type="chain">r1</result>//访问action,注意前面最好不要加/,属于服务器端跳转
</action>
<action name="r4">
<result type="redirectAction">r2</result>//客户端直接跳转到action
</action>
</package>
前两个最常用!!
一包中的struts配置可以从另外一个包中继承,访问别的包的result
<struts>
<constant name="struts.devMode" value="true" />
<package name="user" namespace="/user" extends="struts-default">
<global-results>
<result name="mainpage">/main.jsp</result>
</global-results>
<action name="index">
<result>/index.jsp</result>
</action>
<action name="user" class="com.bjsxt.struts2.user.action.UserAction">
<result>/user_success.jsp</result>
<result name="error">/user_error.jsp</result>
</action>
</package>
<package name="admin" namespace="/admin" extends="user">
<action name="admin" class="com.bjsxt.struts2.user.action.AdminAction">
<result>/admin.jsp</result>
</action>
</package>
</struts>
<global-results> 所有action都可以用的result 例如错误页面跳转
<package name="user" namespace="/user" extends="struts-default">
<global-results>
<result name="mainpage">/main.jsp</result>
</global-results>
<action name="index">
<result>/index.jsp</result>
</action>
<action name="user" class="com.bjsxt.struts2.user.action.UserAction">
<result>/user_success.jsp</result>
<result name="error">/user_error.jsp</result>
</action>
</package>
带有参数的Result
struts.xml
<struts>
<constant name="struts.devMode" value="true" />
<package name="user" namespace="/user" extends="struts-default">
<action name="user" class="com.bjsxt.struts2.user.action.UserAction">
<result type="redirect">/user_success.jsp?t=${type}</result>
</action>
</package>
</struts>
##Result总结:##
Result种类:
1.默认为dispatcher
2.redirect
以上两种常用
3.chain
4.redirectAction
全局结果集:
global-results | extends
多个action共享一个result时,使用global-results ,当希望共享其他package里的global-results时,使用extends继承那个包
动态结果集,了解即可
在action设置一个属性,保存具体的result的值location,跳转的路径.然后在配置文件中使用${将该属性得到}
传递参数
a)客户端传递才需要
b)${}表达式不是el,${}从valuestack中取值
**Struts2 之 OGNL表达式**
**Struts2 之 struts标签**
1.通用标签:
a>property
b>set
i.默认为action scope,会将值放入 request 和 ActionContext中
ii.page,request,session,application
c>bean
d>include(对中文文件支持有问题,不建议使用,如需包含,改用jsp包含)
e>param
f>debug
2.控制标签
a>if elseif else
b>iterator
i.collections map enumeration iterator array
c>subset
3.UI标签
a>theme
i.simple xhtml(默认) css xhtml ajax
4.AJAX标签
a>补充
5.$#%的区别
a>$用于i18n 和 struts配置文件
b>#取得ActionContext的值
c>%将原来的文本属性解析为ognl,对于本来就是ognl的属性不起作用
i.参考<s:property>和<s:include>