前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >spring security中权限注解

spring security中权限注解

作者头像
用户10325771
发布2023-03-01 17:24:55
6560
发布2023-03-01 17:24:55
举报

文章目录[隐藏]

@PreAuthorize

方法调用之前, @EnableGlobalMethodSecurity(prePostEnabled=true)

  • 根据角色限制权限
代码语言:javascript
复制
@PostMapping
@PreAuthorize("hasRole('ROLE_USER') or hasRole('ROLE_ADMIN')")
public R<Boolean> insertUser(@RequestBody UserDTO userDTO){
    return success(this.userService.saveUserDTO(userDTO));
}
  • SpEL 表达式
代码语言:javascript
复制
@PostMapping
@PreAuthorize("#id<10")
public R<Boolean> insertUser(@RequestBody UserDTO userDTO){
    return success(this.userService.saveUserDTO(userDTO));
}
代码语言:javascript
复制
@PostMapping
@PreAuthorize("principal.username.equals(#username)")
public R<Boolean> insertUser(@RequestBody UserDTO userDTO){
    return success(this.userService.saveUserDTO(userDTO));
}
代码语言:javascript
复制
@PostMapping
@PreAuthorize("#user.name.equals('abc')")
public R<Boolean> insertUser(@RequestBody UserDTO userDTO){
    return success(this.userService.saveUserDTO(userDTO));
}

@PostAuthorize

方法调用之后,设置@EnableGlobalMethodSecurity(prePostEnabled=true)

@PreFilter和@PostFilter

       使用@PreFilter和@PostFilter可以对集合类型的参数或返回值进行过滤。使用@PreFilter和@PostFilter时,Spring Security将移除使对应表达式的结果为false的元素。

代码语言:javascript
复制
@PostFilter(filterTarget="ids",value="filterObject.id%2==0")
public R<User> select(List<Long> ids,User user){
    return success(this.userService.selectAll(ids));
}

上述代码表示将对返回结果中id不为偶数的user进行移除。filterObject是使用@PreFilter和@PostFilter时的一个内置表达式,表示集合中的当前对象。当@PreFilter标注的方法拥有多个集合类型的参数时,需要通过@PreFilter的filterTarget属性指定当前@PreFilter是针对哪个参数进行过滤的。 filterTarget指定了当前@PreFilter是用来过滤参数ids的 .

区别

综合其他方式

方法授权类型

声明方式

JSR标准

允许SpEL表达式

@PreAuthorize@PostAuthorize

注解

No

Yes

@RolesAllowed@PermitAll@DenyAll

注解

Yes

NO

@Secure

注解

No

No

protect-pointcut

XML

No

No

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2021-06-04),如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • @PreAuthorize
  • @PostAuthorize
  • @PreFilter和@PostFilter
  • 区别
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档