《权限系列》----用SpringAop控制权限一

2024-08-27 20:38
文章标签 系列 控制 权限 springaop

本文主要是介绍《权限系列》----用SpringAop控制权限一,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

  • 在一些公司内部用的局域网项目中,常常用SpringAop来控制权限,这种控制权限的方式实现起来相对简单,原理是自定义一个注解,然后定义一个切面,再加一个拦截器,当我们每次访问后台数据时,用拦截器判断用户是否登录(session是否存在),然后利用SpringAop的前置通知判断用户访是否有权限访问此方法。

主要技术

  • SpringMvc+Spring+MyBatis

项目源码

点击这里,到github上下载项目的源码

注意

  • 小编在此只将部分代码贴上,要想看完整项目,小编会在最后附上代码。

配置SpringMvc拦截器

<!-- handle the json -->
<mvc:annotation-driven/>
......
......
......<!--配置拦截器 -->
<mvc:interceptors><mvc:interceptor><mvc:mapping path="/**" />  <mvc:exclude-mapping path="/login" /><mvc:exclude-mapping path="/loginsubmit" /><bean class="com.spring.security.SecurityInterceptor"></bean></mvc:interceptor>
</mvc:interceptors><!-- 配置切面 -->
<bean id="aspectPermission" class="com.spring.security.PermissionAspect" />
<!-- 配置切入点 -->
<aop:config proxy-target-class="true">  <aop:aspect ref="aspectPermission">  <aop:pointcut id="pc"       expression="@annotation(com.spring.security.ValidatePermission) and execution(* com.spring.mybatis.controller..*.*(..)) " />  <aop:before pointcut-ref="pc" method="doBefore"/>  </aop:aspect>  
</aop:config><!-- 当用户访问没有权限的方法时,抛出自定义异常AccessDeniedException,在此抓住此异常后,转发到没有权限页面 -->
<bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver"><property name="exceptionMappings"><props><prop key="com.spring.security.AccessDeniedException">forward:/accessDenied</prop></props></property>
</bean>

SpringMvc拦截器代码

public boolean preHandle(HttpServletRequest request,HttpServletResponse response, Object obj) throws Exception {HttpSession session = request.getSession();if (session.getAttribute("userLoginName") == null) {if ("POST".equalsIgnoreCase(request.getMethod())) {response.setContentType("text/html; charset=utf-8");PrintWriter out = response.getWriter();out.write(JsonUtils.objectToJson(new Result(false, "未登录!")));out.flush();out.close();} else {response.sendRedirect(request.getContextPath() + "/login");}return false;} else {return true;}
}

拦截器主要是判断用户是否登录。

写一个自定义权限注解

@Target(value = ElementType.METHOD)
@Retention(value = RetentionPolicy.RUNTIME)
@Documented
public @interface ValidatePermission {String authority() default "";
}
  • 此注解放在Controller的方法上,当我们每次访问Controller的方法时,springaop的切面中的前置通知就会执行,判断用户是否拥有权限访问此方法。

自定义异常代码

public class AccessDeniedException extends RuntimeException  {public AccessDeniedException(String message) {super(message);}
}

小结

为了适应读者,故将博客的篇幅设置小一些,切面代码请看下一篇博客。

这篇关于《权限系列》----用SpringAop控制权限一的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1112719

相关文章

用js控制视频播放进度基本示例代码

《用js控制视频播放进度基本示例代码》写前端的时候,很多的时候是需要支持要网页视频播放的功能,下面这篇文章主要给大家介绍了关于用js控制视频播放进度的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言html部分:JavaScript部分:注意:总结前言在javascript中控制视频播放

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

使用DrissionPage控制360浏览器的完美解决方案

《使用DrissionPage控制360浏览器的完美解决方案》在网页自动化领域,经常遇到需要保持登录状态、保留Cookie等场景,今天要分享的方案可以完美解决这个问题:使用DrissionPage直接... 目录完整代码引言为什么要使用已有用户数据?核心代码实现1. 导入必要模块2. 关键配置(重点!)3.

SpringSecurity 认证、注销、权限控制功能(注销、记住密码、自定义登入页)

《SpringSecurity认证、注销、权限控制功能(注销、记住密码、自定义登入页)》SpringSecurity是一个强大的Java框架,用于保护应用程序的安全性,它提供了一套全面的安全解决方案... 目录简介认识Spring Security“认证”(Authentication)“授权” (Auth

python之流程控制语句match-case详解

《python之流程控制语句match-case详解》:本文主要介绍python之流程控制语句match-case使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录match-case 语法详解与实战一、基础值匹配(类似 switch-case)二、数据结构解构匹

Spring Security注解方式权限控制过程

《SpringSecurity注解方式权限控制过程》:本文主要介绍SpringSecurity注解方式权限控制过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、摘要二、实现步骤2.1 在配置类中添加权限注解的支持2.2 创建Controller类2.3 Us

Redis实现RBAC权限管理

《Redis实现RBAC权限管理》本文主要介绍了Redis实现RBAC权限管理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1. 什么是 RBAC?2. 为什么使用 Redis 实现 RBAC?3. 设计 RBAC 数据结构

Python中如何控制小数点精度与对齐方式

《Python中如何控制小数点精度与对齐方式》在Python编程中,数据输出格式化是一个常见的需求,尤其是在涉及到小数点精度和对齐方式时,下面小编就来为大家介绍一下如何在Python中实现这些功能吧... 目录一、控制小数点精度1. 使用 round() 函数2. 使用字符串格式化二、控制对齐方式1. 使用

Springboot控制反转与Bean对象的方法

《Springboot控制反转与Bean对象的方法》文章介绍了SpringBoot中的控制反转(IoC)概念,描述了IoC容器如何管理Bean的生命周期和依赖关系,它详细讲解了Bean的注册过程,包括... 目录1 控制反转1.1 什么是控制反转1.2 SpringBoot中的控制反转2 Ioc容器对Bea

Vue中动态权限到按钮的完整实现方案详解

《Vue中动态权限到按钮的完整实现方案详解》这篇文章主要为大家详细介绍了Vue如何在现有方案的基础上加入对路由的增、删、改、查权限控制,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、数据库设计扩展1.1 修改路由表(routes)1.2 修改角色与路由权限表(role_routes)二、后端接口设计