快速搭建一个springmvc拦截器

第一步:在springmvc.xml中配置拦截器的位置
<!-- 		拦截器 -->
	<mvc:interceptors>
		<bean class="com.qzs.interceptor.SystemInterceptor" />
	</mvc:interceptors>  

第二步:配置拦截器

//普通类继承HandlerInterceptorAdapter就可以
public class SystemInterceptor extends HandlerInterceptorAdapter {
	/**
	 * 在业务处理器处理请求之前被调用 如果返回false 拦截 如果返回true 继续
	 */
	@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 path = request.getServletPath();//获取当前访问路径
		String root = request.getContextPath();//获取项目的上下文
		String noFilter = ".*/((tologin)|(toregister)|(register)|(loginmain)|(getCode)|(common)|(file)|(portal)|(getAllList)|(getByPid)).*";//配置不需要session拦截的方法
		if(path.matches(noFilter)){//正则匹配,不需要拦截的返回TRUE,放行
			return true;
		} else{
			Object obj = request.getSession().getAttribute("user");//获取用户对象session
			if (null == obj) {//如果session为null,表示没有登录
				//如果没有登录,跳转到登录页面
				PrintWriter out = response.getWriter();
				StringBuilder builder = new StringBuilder();
				builder.append("<script type=\"text/javascript\" charset=\"UTF-8\">");
				builder.append("window.top.location.href=\"");
				builder.append(root);
				builder.append("/login/tologin.action\";</script>");
				out.print(builder.toString());
				out.close();
				return false;
			}
		}
		return true;
	}
}

第三步:在controller层定义一个tologin方法

package com.qzs.controller.login;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@RequestMapping("login")
@Controller
public class Login {
	
	@RequestMapping("tologin")
	public String tologin(){
		return "jsp/login.jsp";
	}

}

第四步:转发到登录界面

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<%
    request.setAttribute("ctx", request.getContextPath());
%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
	这是拦截器的作用,欢迎来到登录界面
</body>
</html>

然后随机一个访问都会被拦截


欢迎大家点评,多多支持,希望能够帮助一些同志早日步入程序员的行列




猜你喜欢

转载自blog.csdn.net/Romantic_321/article/details/80755183
今日推荐