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-15鸿蒙生态设备数量超8亿台
- 2024-05-13TiDB + ES:转转业财系统亿级数据存储优化实践
- 2024-05-09“2024鸿蒙零基础快速实战-仿抖音App开发(ArkTS版)”实战课程已上线
- 2024-05-09聊聊如何通过arthas-tunnel-server来远程管理所有需要arthas监控的应用
- 2024-05-09log4j2这么配就对了
- 2024-05-09nginx修改Content-Type
- 2024-05-09Redis多数据源,看这篇就够了
- 2024-05-09Google Chrome驱动程序 124.0.6367.62(正式版本)去哪下载?
- 2024-05-09有没有大佬知道这种数据应该怎么抓取呀?
- 2024-05-09这种运行结果里的10.100000001,怎么能最快改成10.1?