日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

[SpringSecurity]web权限方案_用户授权_注解使用

發布時間:2023/12/4 javascript 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 [SpringSecurity]web权限方案_用户授权_注解使用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

注解使用

@Secured

判斷用戶是否具有角色,可以訪問方法,另外需要注意的是這里匹配的字符串需要添加前綴“ROLE_“。

使用注解先要開啟注解功能!

啟動類(配置類)開啟注解

  • @EnableGlobalMethodSecurity(securedEnable = true)

在controller的方法上面使用注解,設置角色

@RestController @RequestMapping("/test") public class TestController {@GetMapping("hello")public String hello(){return "hello security";}@GetMapping("index")public String index(){return "hello index";}@GetMapping("update")@Secured({"ROLE_sale","ROLE_manager"})public String update(){return "hello update";} }

userDetailsService設置用戶角色

測試

@PreAuthorize

適合進入方法前的權限驗證

啟動類開啟注解

在controller的方法上面添加注解

userDetailsService設置用戶角色

測試

@PostAuthorize

在方法執行后再進行權限驗證,適合驗證帶有返回值的權限.

開啟注解

  • @EnableGlobalMethodSecurity(prePostEnabled = true)

在controller的方法上面添加注解

測試



可以看到沒有訪問權限,但是控制臺還是輸出了update…,說明在方法執行后再進行權限驗證!

@PostFilter

  • 方法返回數據進行過濾

@PostFilter :權限驗證之后對數據進行過濾 留下用戶名是 admin1 的數據

表達式中的 filterObject 引用的是方法返回值 List 中的某一個元素

測試

package com.atguigu.securitydemo1.entity;import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor;@Data @AllArgsConstructor @NoArgsConstructor public class Users {private Integer id;private String username;private String password;} @GetMapping("getAll")@PostAuthorize("hasAnyAuthority('admins')")@PostFilter("filterObject.username == 'admin1'")public List<Users> getAllUser(){ArrayList<Users> list = new ArrayList<>();list.add(new Users(11,"admin1","6666"));list.add(new Users(21,"admin2","888"));System.out.println(list);return list;}

@PreFilter

  • 傳入方法數據進行過濾

@PreFilter: 進入控制器之前對數據進行過濾

總結

以上是生活随笔為你收集整理的[SpringSecurity]web权限方案_用户授权_注解使用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。