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;
}//上接
相关推荐
林希_Rachel_傻希希12 小时前
js里面的proxy理解。以及vue3响应式数据设计底层
前端·javascript·面试
sunrains12 小时前
uniapp x 动态Tabbar(切换无闪烁)+动角标+主题切换+自定义tabbar页面导航栏样式设置 支持服务端动态配置根据角色动态设置Tabbar
前端
把马铃薯变成土豆12 小时前
前端Stripe跨境支付对接感想
前端·源码
牧艺12 小时前
用 Three.js 实现一个浏览器端 3D 看车的项目
前端·three.js
hunterandroid12 小时前
WorkManager:可靠的后台任务调度
前端
hunterandroid12 小时前
[Android 从零到一] Navigation Component:让页面跳转更清晰
前端
搬砖的码农12 小时前
(05)进程一关对话就没了:聊天记录怎么存、重启怎么恢复
前端·agent·ai编程
Csvn14 小时前
Vue 3 defineModel 翻车实录:多个 v-model 绑定到底怎么写?
前端·vue.js
甲维斯14 小时前
坦克大战测试全翻车了!豆包,DeepSeek,Qwen,GPT,Claude
前端·人工智能·游戏开发
乘风gg14 小时前
还在养虾吗?虾王已诞生:微信龙虾 ClawBot
前端·ai编程·claude