国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

SpringMVC表當重復提交

2019-11-15 01:18:13
字體:
來源:轉載
供稿:網友
SPRingMVC表當重復提交

最近公司上線,有同志進行攻擊,表當防重復提交也沒有弄,交給我 ,本人以前也沒弄過,知道大概的思路,但是那樣實在是太麻煩了,雖然后面試過使用過濾器加攔截器實現,不過還是有點小麻煩。

后來在網上搜索后發現不錯的方案如下:注解加攔截器完成

首先創建注解token:

@Target(ElementType.METHOD)@Retention(RetentionPolicy.RUNTIME)設置注解的作用范圍public @interface Token {

boolean save() default false;

boolean remove() default false;}

創建token攔截器:

public class TokenInterceptor extends HandlerInterceptorAdapter {

  @Override  public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { if (handler instanceof HandlerMethod) { HandlerMethod handlerMethod = (HandlerMethod) handler; Method method = handlerMethod.getMethod();

    Token annotation = method.getAnnotation(Token.class);    if (annotation != null) {      boolean needSavesession = annotation.save();      if (needSaveSession) {      request.getSession(false).setAttribute("token", UUID.randomUUID().toString());       }       boolean needRemoveSession = annotation.remove();       if (needRemoveSession) {         if (isRepeatSubmit(request)) {           return false;         }         request.getSession(false).removeAttribute("token");     }   }     return true;   } else {     return super.preHandle(request, response, handler);   }   }

  private boolean isRepeatSubmit(HttpServletRequest request) {     String serverToken = (String) request.getSession(false).getAttribute("token");     if (serverToken == null) {       return true;     }     String clinetToken = request.getParameter("token");     if (clinetToken == null) {       return true;     }     if (!serverToken.equals(clinetToken)) {       return true;     }       return false;   }}

然后在配置文件中配置好攔截器:注意這種方式在配置注解的處理器的時候需要配置:請求映射的方法處理器以及請求映射處理的適配器,如果使用

<bean class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping" />這個默認的會找不到方法處理器

  

<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping">   <property name="interceptors">     <list>       <bean class="com.rbao.east.interceptor.TokenInterceptor"/>     </list>   </property> </bean> <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/>

然后在需要生成token的方法上面添加@Token(save = true)

需要進行校驗的方法上添加@Token(remove = true)

最后在顯示頁面上添加隱藏字段<input type="hidden" name="token" value="${token}" />

本文來自:

http://blog.icoolxue.com/submitted-by-spring-mvc-to-prevent-data-duplication/

以及

http://chenzhou123520.VEvb.com/blog/1702563

結合

Spring太'激情'了.有好的文章希望能推薦推薦

如果有什么好的方案,希望各位朋友推薦推薦相互學習,多謝~~~


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 开平市| 洱源县| 剑阁县| 兴隆县| 托里县| 托克逊县| 正镶白旗| 尼木县| 兴海县| 松滋市| 尖扎县| 林芝县| 阿勒泰市| 宝山区| 昌宁县| 长垣县| 曲周县| 彭山县| 天峻县| 威远县| 牡丹江市| 永济市| 楚雄市| 海阳市| 玛多县| 贡山| 奎屯市| 兴山县| 普兰县| 彰化县| 阜新| 高要市| 修武县| 绍兴市| 新平| 常宁市| 德惠市| 青海省| 桦南县| 宣威市| 曲麻莱县|