spring3.0 MVC初步5-利用拦截器防止SQL注入

本文详细介绍了如何实现SQL注入拦截器,并通过配置确保其在应用中的有效使用。重点阐述了拦截器类的实现逻辑,包括参数解析、攻击字符串检测及响应策略,以及如何在MVC框架中进行拦截器的配置。

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

一、定义拦截器类实现HandlerInterceptor接口

public class SqlInjectIntercepter implements HandlerInterceptor {

 @Override
 public void afterCompletion(HttpServletRequest arg0,
   HttpServletResponse arg1, Object arg2, Exception arg3)
   throws Exception {
 }

 @Override
 public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1,
   Object arg2, ModelAndView arg3) throws Exception {
 }

 @Override
 public boolean preHandle(HttpServletRequest request, HttpServletResponse response,
   Object arg2) throws Exception {
  Enumeration<String> names = request.getParameterNames();
  while (names.hasMoreElements()) {
   String name = names.nextElement();
   String[] values = request.getParameterValues(name);
   for (int i = 0; i < values.length; i++) {
    if(Utility.hasAttackStr(values[i])){
     if(!(values[i].equals("DELETE") && name.equals("_method")) ){
      response.setContentType("text/html;charset=utf-8");
      response.getWriter().print("请不要尝试注入<br><a href='#' onclick='history.go(-1)'>返回</a>");
      return false;
     }
    }
   }
  }
  return true;
 }
}

二、配置拦截器

 <mvc:interceptors>
  <!-- mvc:interceptor>
   <mvc:mapping path="/**"/ -->
   <bean class="com.tdrc.common.controller.SqlInjectIntercepter"/>
  <!-- /mvc:interceptor-->
 </mvc:interceptors>
注意要写在<mvc:annotation-driven/>后面,否则拦截器不起作用。

 

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值