SpringSecurity的注解@PreAuthorize(“@ss.hasPermi(‘system:config:list‘)“)实现流程

1、代码示例

今天项目做权限控制,发现项目里别人的做法很方便,特此记录实现过程。

在这里插入图片描述
在这里插入图片描述
逻辑方法这里省略,具体参考下面的链接

在这里插入图片描述

2、思路介绍

实现思路就是使用SpringSecurity框架,开启权限校验@EnableGlobalMethodSecurity注解,第二步自动校验规则的方法hasPermi()方法,逻辑自己实现,第三步就可以使用@PreAuthorize注解,被此注解标注的方法就是走你hasPermi()方法的逻辑,返回布尔值,从来决定是否有权限访问。

参考链接

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: @preauthorize(@ss.haspermi) 是Spring Security中的注解,用于在方法执行前进行权限检查。其中 @ss.haspermi 是自定义的权限表达式,表示当前用户是否拥有某个权限。 具体来说,当一个方法被 @preauthorize(@ss.haspermi) 注解修饰时,Spring Security会在方法执行前调用 SecurityExpressionRoot 类的 hasPermission 方法,该方法会根据 @ss.haspermi 中定义的权限表达式,判断当前用户是否有权限执行该方法。 例如,@preauthorize("@ss.haspermi('user:add')") 表示只有拥有 "user:add" 权限的用户才能执行该方法。如果当前用户没有该权限,则会抛出 AccessDeniedException 异常,方法不会被执行。 总之,@preauthorize(@ss.haspermi) 注解Spring Security 中非常重要的权限控制注解,可以帮助我们实现精细化的权限控制。 ### 回答2: @preauthorize(@ss.haspermi 这是一个Spring Security注解,它用来控制方法或类是否被授权访问。@preauthorize表示在方法调用前先进行权限检查,如果用户没有相应权限,则不允许访问该方法。 @ss.haspermi表示只有拥有指定权限的用户才能访问该方法或类。 在Spring Security中,可以通过配置SecurityConfig来设置各种权限配置。在SecurityConfig中可以设置用户、角色、资源以及访问控制等信息,通过这些配置可以控制Spring应用程序中的访问控制。@preauthorize和@ss.haspermi就是Spring Security控制访问的重要注解之一。 使用这些注解,首先需要在pom.xml中引入spring-security-core和spring-security-config两个jar包,然后在配置类中使用@EnableGlobalMethodSecurity注解启用Spring Security方法级别的安全功能。接着,在方法或类中使用@preauthorize和@ss.haspermi注解来控制访问授权。这样,当用户访问需要授权的方法时,Spring Security会先验证用户是否有相应的权限,如果有,则允许访问;否则,则拒绝访问。 @preauthorize和@ss.haspermi注解可以帮助开发者在Spring应用程序中实现精细化的访问控制,提高系统的安全性和可靠性。因此,在开发过程中,合理地使用这些注解可以使开发者的工作变得更加高效和智能。 ### 回答3: @preauthorize(@ss.haspermiSpring Security框架中的一项功能,在应用程序设计中起到了安全保障的作用。@preauthorize是一个注解,用于在代码级别上对用户权限进行判断,并决定是否允许用户执行某些操作。 @ss.hasPermiSpring Security框架中的一个方法,它可以查询当前用户是否具有某种权限。通常情况下,@preauthorize注解与@ss.hasPermi方法是一起使用的,通过配置注解的参数来实现对当前用户是否具备某些操作权限的判断。 在实际应用中,@preauthorize注解通常是用在Controller层的方法中。例如,在一个Java Web应用中,对于某个需要权限才能访问的URL,可以在Controller方法上添加@preauthorize注解,并且指定该URL所需要的权限,比如: @PreAuthorize("@ss.hasPermi('sys:user:add')") 在上述代码中,@preauthorize注解中的@ss.hasPermi('sys:user:add')就是使用了@ss.hasPermi方法查询当前用户是否具有sys:user:add权限。如果用户具有该权限,则该Controller方法将被允许访问,否则会被拒绝访问。 总之,@preauthorize(@ss.hasPermi的使用可以在代码级别上实现对用户权限的授权和访问控制,提高应用程序的安全性和可靠性,是Java Web应用开发中不可或缺的一项技术。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

bst@微胖子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值