SpringMVC ---- 拦截器

概述

SpringMVC的处理器拦截器类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理。开发者可以自己定义一些拦截器来实现特定的功能。

过滤器与拦截器的区别:拦截器是AOP思想的具体应用。

过滤器

  • servlet规范中的一部分,任何java web工程都可以使用
  • 在url-pattern中配置了/*之后,可以对所有要访问的资源进行拦截

拦截器

  • 拦截器是SpringMVC框架自己的,只有使用了SpringMVC框架的工程才能使用
  • 拦截器只会拦截访问的控制器方法, 如果访问的是jsp/html/css/image/js是不会进行拦截的
  • 就是说不会拦截你的静态资源

自定义拦截器

那如何实现拦截器呢?

想要自定义拦截器必须实现 HandlerInterceptor 接口

1、新建一个Moudule , 添加web支持

2、配置好web.xml 和 applicationContext.xml 文件

3、编写一个拦截器

package com.wu.config;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

public class MyInterceptor implements HandlerInterceptor {

	// 在请求处理的方法之前执行
	// return true 执行下一个拦截器,放行
	// return false 不执行下一个拦截器
	@Override
	public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
			throws Exception {
		System.out.println("=============处理前 =============");
		return true;
	}

	// 在请求处理方法执行之后执行
	@Override
	public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
			ModelAndView modelAndView) throws Exception {
		System.out.println("=============处理后 =============");
	}

	// 在dispatcherServlet处理后执行,做清理工作.
	@Override
	public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
			throws Exception {
		System.out.println("=============清理 =============");
	}

}

4、在springmvc的配置文件中配置拦截器

<!-- 拦截器设置 -->
<mvc:interceptors>
	<mvc:interceptor>
		<!--/** 包括路径及其子路径-->
		<mvc:mapping path="/**"/>
		 <!--bean配置的就是自己写的拦截器-->
		<bean class="com.wu.config.MyInterceptor"></bean>
	</mvc:interceptor>
</mvc:interceptors>

5、编写一个Controller,接收请求

@RestController
public class TestController {
	@GetMapping("/t1")
	public String test() {
		System.out.println("控制器中的方法跑起来了");
		return "OK";
	}
}

6、启动tomcat 测试一下!
在这里插入图片描述

验证用户是否登录 (认证用户)

实现思路

1、有一个登陆页面(login.jsp),需要写一个controller访问页面。

2、登陆页面有一提交表单的动作。需要在controller中处理。判断用户名密码是否正确。如果正确,向session中写入用户信息。返回登陆成功。

3、拦截用户请求,判断用户是否登陆。如果用户已经登陆。放行, 如果用户未登陆,跳转到登陆页面

测试:
在这里插入图片描述
1、编写一个index.jsp页面实现跳转

<%@ page language="java" contentType="text/html; charset=UTF-8"
	pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
	<h1>
		<a href="${pageContext.request.contextPath }/user/dologin">登录页面</a>
	</h1>

	<h1>
		<a href="${pageContext.request.contextPath }/user/main">首页</a>
	</h1>
</body>
</html>

2、编写一个登陆页面 login.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
	
	<h1>登录页面</h1>
	
	<form action="${pageContext.request.contextPath }/user/login" method="post">
		用户名:<input type="text" name="username"><br>
		密码:<input type="password" name="password"><br>
		<input type="submit" value="提交">
	</form>
</body>
</html>

3、编写一个Controller处理请求

@Controller
@RequestMapping("/user")
public class LoginController {
	//登陆提交
	@RequestMapping("/login")
	public String login(HttpSession session,String username,String password,Model model) {
		if(username==null) {
			return "redirect:/index.jsp";
		}
		//把用户的信息存到Session中
		session.setAttribute("userLoginInfo", username);
		model.addAttribute("username", username);
		return "main";
	}
	//请求跳转到首页
	@RequestMapping("/main")
	public String main() {
		return "main";
	}
	
	//请求跳转到登录页面
	@RequestMapping("/dologin")
	public String login() {
		return "login";
	}
	
	//退出登陆
	@RequestMapping("/doOut")
	public String doOut(HttpSession session) {
		//移除session
		session.removeAttribute("userLoginInfo");
		return "login";
	}
}

3、编写一个登陆成功的页面 main.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<h1>首页</h1>
<h1>
	<a href="${pageContext.request.contextPath}/user/doOut">注销</a>
	${username }
</h1>
</body>
</html>

4、编写用户登录拦截器


public class LoginInterceptor implements HandlerInterceptor{

	@Override
	public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
			throws Exception {
		//放行:判断什么情况下登录
		//session不为空说明登录过没注销,并且没有关闭过窗口
		HttpSession session = request.getSession();
		if(session.getAttribute("userLoginInfo")!=null) {
			return true;
		}
		
		//登录页面也要放行
		if(request.getRequestURI().contains("login")) {
			return true;
		}
		
		 // 用户没有登陆跳转到登陆页面
		request.getRequestDispatcher("/WEB-INF/jsp/login.jsp").forward(request, response);
		
		return false;
	}
	
}

5、在Springmvc的配置文件中注册拦截器

<mvc:interceptors>
	<mvc:interceptor>
		<!-- 包括这个请求下面的所有的请求 -->
		<mvc:mapping path="/user/**"/>
		<bean class="com.wu.config.LoginInterceptor"></bean>
	</mvc:interceptor>
</mvc:interceptors>

6、启动Tomcat测试一下

说明:这个登录有可能存在BUG,哈哈,因为我只是为了说明拦截器是长啥样的

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值