Struts Token 使用

本文介绍了Struts框架中防止表单重复提交的机制。通过在首个Action中生成唯一令牌并保存到session,随后在JSP页面利用Struts自定义标签生成隐藏字段,最后在提交表单时验证令牌的有效性来确保请求的唯一性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1,先在一个Action中,调用saveToken(HttpServletRequest request)方法。然后转向带有表单的JSP页面。 2,在JSP页面提交表单给一个Action,再这个Action中进行是否为重复提交的判断。 if (isTokenValid(request, true)) { // 未重复提交时,正确的时候应该做的事情 return mapping.findForward("success"); } else { // 重复提交时,需要做的事情 saveToken(request); return mapping.findForward("error"); } Struts Token 机制: 1, 由第一个Action调用saveToken(HttpServletRequest request),这个方法内部实现如下: protected void saveToken(HttpServletRequest request) { token.saveToken(request); } token.saveToken(request);这个方法的实现如下: public synchronized void saveToken(HttpServletRequest request) { HttpSession session = request.getSession(); String token = generateToken(request); if (token != null) { session.setAttribute(Globals.TRANSACTION_TOKEN_KEY, token); } } 这个方法调用generateToken方法实现如下: public synchronized void saveToken(HttpServletRequest request) { HttpSession session = request.getSession(); String token = generateToken(request); if (token != null) { session.setAttribute(Globals.TRANSACTION_TOKEN_KEY, token); } } generateToken完毕后,将得到的唯一值setAttribute到session中。 session.setAttribute(Globals.TRANSACTION_TOKEN_KEY, token); Globals.TRANSACTION_TOKEN_KEY的值是:” org.apache.struts.action.TOKEN” 然后跳转到JSP页面。 2, JSP页面的Struts自定义标签 的标签类:org.apache.struts.taglib.html. FormTag 这个类的doStartTag()方法会调用本类的renderToken()方法。 protected String renderToken() { StringBuffer results = new StringBuffer(); HttpSession session = pageContext.getSession(); if (session != null) { String token =(String) session.getAttribute(Globals.TRANSACTION_TOKEN_KEY); if (token != null) { results.append(""); } else { results.append("\">"); } } } return results.toString(); } 这样子会生成类似于 的隐藏标签。 然后提交到一个Action中,在Action中用isTokenValid()方法进行比较session中” org.apache.struts.action.TOKEN”的这个key所对应的值和提交来的request中的” org.apache.struts.action.TOKEN”的这个value是否一致。 如果为true,那么证明可以提交。如果为false,证明已经重复,不允许提交。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值