Web开发-拦截器介绍

目录

拦截器的主要作用

  • 完成请求参数的解析,将页面表单参数赋给值栈中相应属性,执行功能检验,程序异常调试等工作。
  • 在MVC设计模式的框架下,拦截器可以对用户的请求进行全局拦截,对多个Controller做拦截,并且常用在用户登录处理、权限检查、记录日志等方面。
  • MVC 中的拦截器 (Interceptor) 主要用于对请求进行拦截和处理,它可以在请求处理之前或之后执行一些操作,例如记录日志、验证权限、数据校验等。
  • 拦截器可以在控制器方法执行之前或之后执行,也可以在视图渲染之前或之后执行。通过使用拦截器,可以提高应用程序的安全性、性能和可维护性。

场景:验证用户登录是否有效

  • 比如说登录页面的网址是***/login,登录后的主页的网址是***/index,这里的拦截器就是为了防止没有登录的用户/登录过时的用户点击登录后【Ajax请求】直接跳转到主页而设计

拦截Ajax请求

java 复制代码
String requestURI = request.getRequestURI();
HttpSession session = request.getSession();
Object attribute = session.getAttribute(SessionConstant.SESSION_USER_LOGIN_KEY);
if(attribute == null){
	log.info("用户还未登录或者session失效,重定向到登录页面,当前URL=" + requestURI);
	//首先判断是否是ajax请求
	if(StringUtil.isAjax(request)){
		//表示是ajax请求,那么就返回错误信息
		try {
			response.setCharacterEncoding("UTF-8");
			response.getWriter().write(JSON.toJSONString(CodeMsg.USER_SESSION_EXPIRED));
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return false;
	}//下接

拦截其他请求

  • 【比如未登录但直接输入了主页的网址】
java 复制代码
	try {
		response.sendRedirect("/system/login");
	} catch (IOException e) {
		// TODO Auto-generated catch block
		e.printStackTrace();
	}
	return false;
}//上接
相关推荐
kyriewen14 分钟前
WebAssembly:前端界的“外挂”,让C++代码在浏览器里跑起来
前端·c++·webassembly
悟空和大王16 分钟前
核心 SDK 详细设计文档 (Visual-Render-SDK)
前端
傻瓜搬砖人19 分钟前
SpringBoot整合Junit-Redis-打包
spring boot·redis·junit
014-code22 分钟前
布隆过滤器:判断“可能存在“和“一定不存在“
java·redis
兔小盈23 分钟前
多线程篇-(二)线程创建、中断与终止
java·开发语言·多线程
jnrjian28 分钟前
Library Cache Load Lock library cache pins are replaced by mutexes
java·后端·spring
abcnull37 分钟前
传统的JavaWeb项目Demo快速学习!
java·servlet·elementui·vue·javaweb
risc12345643 分钟前
【lucene】PostingsEnum跟TermsEnum 的区别是啥?
java·lucene
AI砖家1 小时前
Claude Code Superpowers 安装使用指南:让 AI 编程从“业余”走向“工程化”
前端·人工智能·python·ai编程·代码规范