您的位置:首页 > 编程语言 > Java开发

struts2中的几个技术

2016-05-20 13:09 387 查看

数据回显

数据回显,必须要用struts标签!


Action中

// 进入修改页面
public String viewUpdate() {
// 模拟一个对象(先获取一个id,再根据id调用service查询,把查到的结果保存到域)
User userInfo = new User();
userInfo.setUserName("Jack");
userInfo.setEmail("yuanjie@itcast.cn");

ActionContext ac = ActionContext.getContext();
//      Map<String,Object> request = (Map<String, Object>) ac.get("request");
//      request.put("userInfo", userInfo);

/************* 数据回显***************/
// 获取值栈
ValueStack vs = ac.getValueStack();
vs.pop();// 移除栈顶元素
vs.push(userInfo);  // 入栈

// 进入修改页面
return "viewUpdate";
}


JSP页面

<body>
<%@taglib uri="/struts-tags" prefix="s" %>

<br/>
<!-- 在页面文本框内,显示要修改记录的数据 -->

<!-- 手动通过value设置显示的值
<s:form action="#">

用户名: <s:textfield name="user.userName" value="%{#request.userInfo.userName}"></s:textfield>   <br/>

邮箱: <s:textfield name="user.email" value="%{#request.userInfo.email}"></s:textfield>     <br/>
</s:form>
-->

<!-- 数据回显技术:s:textfield会自动查找根元素数据(Ognl表达式语言取值)  -->
<s:form action="#">

用户名: <s:textfield name="userName"></s:textfield>   <br/>

邮箱: <s:textfield name="email"></s:textfield>     <br/>
</s:form>

<s:debug></s:debug>
</body>


模型驱动

Struts运行时候,会执行默认的拦截器栈,其中有一个拦截器,模型驱动拦截器:
<interceptor
name="modelDriven" class="com.opensymphony.xwork2.interceptor.ModelDrivenInterceptor"/>


部分源码

@Override
public String intercept(ActionInvocation invocation) throws Exception {
Object action = invocation.getAction();

if (action instanceof ModelDriven) {
ModelDriven modelDriven = (ModelDriven) action;
ValueStack stack = invocation.getStack();
Object model = modelDriven.getModel();
if (model !=  null) {
stack.push(model);
}
if (refreshModelBeforeResult) {
invocation.addPreResultListener(new RefreshModelBeforeResult(modelDriven, model));
}
}
return invocation.invoke();
}


引入

情景: 有一个用来处理客户的 CustomerAction 类, 该动作类实现了 ModelDriven 接口.
当用户触发CustomerAction 动作时, ModelDriven 拦截器将调用相关CustomerAction 对象的 getModel() 方法, 并把返回的模型(Customer实例)压入到 ValueStack 栈. 接下来 Parameters 拦截器将把表单字段映射到 ValueStack 栈的栈顶对象的各个属性中. 因为此时 ValueStack 栈的栈顶元素是刚被压入的模型(Product)对象, 所以该模型将被填充. 如果某个字段在模型里没有匹配的属性, Param 拦截器将尝试 ValueStack 栈中的下一个对象.
一个模型类必须有一个不带任何参数的构造器


prams拦截器,可以把请求数据自动填充的action的属性中

举例1:
JSP
<input type=text name=userName />
<input type=text name=pwd />

Action
class UserAction{
// 封装请求数据
private String userName;
private String pwd;
//.. set方法
}

举例2:
JSP
<input type=text name=user.userName />
<input type=text name=user.pwd />

Action
class UserAction{
// 封装请求数据
private User user;

..
}

举例3:(模型驱动)
JSP
<input type=text name=userName />
<input type=text name=pwd />

Action
class UserAction{
// 封装请求数据
private User user;

..
}


步骤及原理

步骤:
1. 实现ModelDriver接口
2. 实现接口方法: 接口方法返回的就是要封装的对象
3. 对象一定要实例化。


/**
* 2. 模型驱动
*/
public class UserAction extends ActionSupport implements ModelDriven<User> {

// 封装请求数据
private User user = new User();
public void setUser(User user) {
this.user = user;
}
public User getUser() {
return user;
}

// 实现模型驱动接口方法
@Override
public User getModel() {
return user;
}

public String add() {
// 测试: 使用了模型驱动,是否数据正常? Ok
System.out.println(user);
return "success";
}


防止表单重复提交

<s:token />标签防止重复提交,用法如下:
第一步:在表单中加入<s:token />


<s:form action="helloworld_other" method="post" namespace="/test">
<s:textfield name="person.name"/><s:token/><s:submit/>
</s:form>


第二步:


<action name="helloworld_*" class="cn.itcast.action.HelloWorldAction" method="{1}">
<interceptor-ref name="defaultStack"/>
<!-- 增加令牌拦截器 -->
<interceptor-ref name="token">
<!-- 哪些方法被令牌拦截器拦截 -->
<param name=“includeMethods">save</param>
</interceptor-ref>
<!-- 当表单重复提交转向的页面 -->
<result name="invalid.token">/WEB-INF/page/message.jsp</result>
</action>


以上配置加入了“token”拦截器和“invalid.token”结果,因为“token”拦截器在会话的token与请求的token不一致时,将会直接返回“invalid.token”结果。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: