ognl 防止表单重复提交

 

第一步:在表单中加入 <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 结果。
 
debug 状态 , 控制台出现下面信息 , 是因为 Action 中并没有 struts.tokenstruts.token.name 属性 , 我 们不用关心这个错误:
严重 : ParametersInterceptor - [setParameters]: Unexpected Exception caught setting 'struts.token' on 'class xxx: Error setting expression 'struts.token' with value '[Ljava.lang.String;@39f16f'
严重 : ParametersInterceptor - [setParameters]: Unexpected Exception caught setting 'struts.token.name'
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值