springmvc拦截未登录的请求
2022/8/13 23:24:26
本文主要是介绍springmvc拦截未登录的请求,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
通常我们会遇到这样的业务需求,就是必须登录之后才能访问到资源,没登陆前是进入不了其他界面的,只能在登录界面,拦截其他所有的请求。
首先我们需要新建一个interceptor的包,在下面建一个PrivilegeInterceptor类,这个类需要实现HandlerInterceptor类。这个类的作用是判断用户是否登录,如果登录了在session中读取到admin对象,就开放所有资源。没登陆则为null,返回登录界面。
PrivilegeInterceptor.java
package com.wjb.interceptor; import com.wjb.domain.Admin; import org.springframework.web.servlet.HandlerInterceptor; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; public class PrivilegeInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { //判断用户是否登录 本质:判断session中有无user HttpSession session = request.getSession(); Admin admin = (Admin) session.getAttribute("admin"); if (admin==null){ //没有登录 response.sendRedirect(request.getContextPath()+"/login.html"); return false; } //放行访问目标资源 return true; } }
在spring-mvc.xml中配置权限拦截器。
<!--配置权限拦截器--> <mvc:interceptors> <mvc:interceptor> <!-- 配置对那些资源拦截--> <mvc:mapping path="/**"/> <!-- 配置对哪些资源不拦截--> <mvc:exclude-mapping path="/admin/login"/> <mvc:exclude-mapping path="/login.html" /> <bean class="com.wjb.interceptor.PrivilegeInterceptor"/> </mvc:interceptor> </mvc:interceptors>
完成之后就可以拦截请求了。
这篇关于springmvc拦截未登录的请求的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-01为什么公共事业机构会偏爱 TiDB :TiDB 数据库在某省妇幼健康管理系统的应用
- 2024-04-26敏捷开发:想要快速交付就必须舍弃产品质量?
- 2024-04-26静态代码分析的这些好处,我竟然都不知道?
- 2024-04-26你在测试金字塔的哪一层?(下)
- 2024-04-26快刀斩乱麻,DevOps让代码评审也自动起来
- 2024-04-262024年最好用的10款ER图神器!
- 2024-04-2203-为啥大模型LLM还没能完全替代你?
- 2024-04-2101-大语言模型发展
- 2024-04-17基于SpringWeb MultipartFile文件上传、下载功能
- 2024-04-14个人开发者,Spring Boot 项目如何部署