Spring3中的mvc:interceptors标签配置拦截器

本文介绍如何在 Spring MVC 中配置全局及特定 URL 的拦截器,通过 XML 文件进行设置,实现对请求的预处理逻辑,如权限验证等。

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

这个是在webmvc-config.xml文件中配置的

mvc:interceptors

这个标签用于注册一个自定义拦截器或者是WebRequestInterceptors.

可以通过定义URL来进行路径请求拦截,可以做到较为细粒度的拦截控制。

例如在配置文件加入

<?xml version="1.0" encoding="UTF-8"?>

<beans xmlns="http://www.springframework.org/schema/beans"

xmlns:mvc="http://www.springframework.org/schema/mvc"

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="

http://www.springframework.org/schema/beans

http://www.springframework.org/schema/beans/spring-beans-3.0.xsd

http://www.springframework.org/schema/mvc

http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">

<!-- 以下配置将拦截所有的URL请求 -->

<mvc:interceptors>

<bean class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor" />

</mvc:interceptors>

<!-- 以下配置将拦截特有的URL请求 -->

<mvc:interceptors>

<mvc:interceptor>

<mvc:mapping path="/secure/*"/>

<bean class="org.example.SecurityInterceptor" />

</mvc:interceptor>

<mvc:interceptor>

<mvc:mapping path="/admin/*.do"/>

<bean class="org.example.admin.ControlInterceptor" />

</mvc:interceptor>

</mvc:interceptors>

</beans>

定义的拦截器只需要实现

@Override

public boolean preHandle(HttpServletRequest req,HttpServletResponse res, Object handler)

package org.unism.qms.interceptor; import java.io.PrintWriter;

import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse;

import org.springframework.stereotype.Repository; import org.springframework.web.servlet.handler.HandlerInterceptorAdapter; @Repository public class LoginIntercepter extends HandlerInterceptorAdapter{  @SuppressWarnings({"rawtypes", "unchecked" })  @Override      public boolean preHandle(HttpServletRequest request,              HttpServletResponse response, Object handler) throws Exception {            request.setCharacterEncoding("UTF-8");          response.setCharacterEncoding("UTF-8");          response.setContentType("text/html;charset=UTF-8");            String uri = request.getRequestURI();         //设置不拦截的对象         String[] noFilters = new String[] { "tologin", "common", "js",                  "images", "css", "/qualityFollowing/login", "/user/loadDepartment",                 "/user/loadName", "/imageCheck"};          boolean beFilter = true;         for (String s : noFilters) {              if (uri.indexOf(s) != -1) {                  beFilter = false;                  break;              }          }         if (beFilter == true) {               Object obj = request.getSession().getAttribute("user");               // 未登录               if (null == obj) {                   PrintWriter out = response.getWriter();                   StringBuilder builder = new StringBuilder();                   builder.append("<script type=\"text/javascript\" charset=\"UTF-8\">");                   builder.append("alert(\"本系统需要您登录后才能使用\");");                   builder.append("window.top.location.href=\"");                   builder.append(request.getContextPath());                      builder.append("/user/tologin\";</script>");                      out.print(builder.toString());                      out.close();                      return false;                  }           }           return super.preHandle(request, response, handler);      } }


转载自:http://tang.sheng.hi.blog.163.com/blog/static/118029085201307102800/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值