許可權控制及AOP日誌
文章目錄
使用者關聯角色
查詢使用者可以新增的角色
Controller
//查詢使用者以及使用者可以新增的角色
@RequestMapping("/findUserByIdAndAllRole.do")
public ModelAndView findUserByIdAndAllRole(@RequestParam(name = "id", required = true) String userid) throws Exception {
ModelAndView mv = new ModelAndView();
//1.根據使用者id查詢使用者
UserInfo userInfo = userService.findById(userid);
//2.根據使用者id查詢可以新增的角色
List<Role> otherRoles = userService.findOtherRoles(userid);
mv.addObject("user", userInfo);
mv.addObject("roleList", otherRoles);
mv.setViewName("user-role-add");
return mv;
}
Servic.
List<Role> findOtherRoles(String userId) throws Exception;
Serviceimpl.
@Override
public List<Role> findOtherRoles(String userId) {
return userDao.findOtherRoles(userId);
}
Dao.
@Select("select * from role where id not in (select roleId from users_role where userId=#{userId})")
List<Role> findOtherRoles(String userId);
新增角色
Controller
//給使用者新增角色
@RequestMapping("/addRoleToUser.do")
public String addRoleToUser(@RequestParam(name = "userId", required = true) String userId, @RequestParam(name = "ids", required = true) String[] roleIds) {
userService.addRoleToUser(userId, roleIds);
return "redirect:findAll.do";
}
Service
void addRoleToUser(String userId, String[] roleIds);
ServiceImpl
@Override
public void addRoleToUser(String userId, String[] roleIds) {
for(String roleId:roleIds){
userDao.addRoleToUser(userId,roleId);
}
}
Dao
@Insert("insert into users_role(userId,roleId) values(#{userId},#{roleId})")
void addRoleToUser(@Param("userId") String userId, @Param("roleId") String roleId);
角色關聯許可權
先查詢點選的角色,在查詢根據點選的角色查詢出可以新增的許可權,在進行新增
Controller
//給角色新增許可權
@RequestMapping("/addPermissionToRole.do")
public String addPermissionToRole(@RequestParam(name = "roleId", required = true) String roleId, @RequestParam(name = "ids", required = true) String[] permissionIds) throws Exception {
roleService.addPermissionToRole(roleId, permissionIds);
return "redirect:findAll.do";
}
//根據roleId查詢role,並查詢出可以新增的許可權
@RequestMapping("/findRoleByIdAndAllPermission.do")
public ModelAndView findRoleByIdAndAllPermission(@RequestParam(name = "id", required = true) String roleId) throws Exception {
ModelAndView mv = new ModelAndView();
//根據roleId查詢role
Role role = roleService.findById(roleId); //先查詢出點選的是哪個Role物件
//根據roleId查詢可以新增的許可權 //在根據Use物件找到可以新增的許可權
List<Permission> otherPermissions = roleService.findOtherPermissions(roleId);
mv.addObject("role", role);
mv.addObject("permissionList", otherPermissions);
mv.setViewName("role-permission-add");
return mv;
}
Service
Role findById(String roleId) throws Exception;
List<Permission> findOtherPermissions(String roleId) throws Exception;
void addPermissionToRole(String roleId, String[] permissionIds) throws Exception;
ServiceImpl
@Override
public void addPermissionToRole(String roleId, String[] permissionIds) {
for(String permissionId:permissionIds){
roleDao.addPermissionToRole(roleId,permissionId);
}
}
@Override
public Role findById(String roleId) {
return roleDao.findById(roleId);
}
@Override
public List<Permission> findOtherPermissions(String roleId) {
return roleDao.findOtherPermissions(roleId);
}
Dao
@Select("select * from role where id=#{roleId}")
@Results({
@Result(id = true,property = "id",column = "id"),
@Result(property = "roleName",column = "roleName"),
@Result(property = "roleDesc",column = "roleDesc"),
@Result(property = "permissions",column = "id",javaType = java.util.List.class,many = @Many(select = "com.itheima.ssm.dao.IPermissionDao.findPermissionByRoleId"))
})
Role findById(String roleId);
@Select("select * from permission where id not in (select permissionId from role_permission where roleId=#{roleId})")
List<Permission> findOtherPermissions(String roleId);
@Insert("insert into role_permission(roleId,permissionId) values(#{roleId},#{permissionId})")
void addPermissionToRole(@Param("roleId") String roleId, @Param("permissionId") String permissionId);
許可權控制
![在這裡插入圖片描述](https://img-blo
相關文章
- SpringBoot(一) 如何實現AOP的許可權控制Spring Boot
- Laravel Daily 日誌許可權問題LaravelAI
- spring aop實現簡單的許可權控制功能Spring
- 許可權控制
- Laravel 框架的日誌許可權問題Laravel框架
- Laravel 日誌檔案許可權問題Laravel
- Laravel 日誌有時候有許可權有時候沒有許可權?Laravel
- shiro許可權控制
- artisan日誌 root 許可權解決辦法
- SpringSecurity許可權管理系統實戰—八、AOP 記錄使用者、異常日誌SpringGse
- 記一次 Laravel日誌許可權許可權問題(定時器導致)Laravel定時器
- 如何用 Vue 實現前端許可權控制(路由許可權 + 檢視許可權 + 請求許可權)Vue前端路由
- SpringAop實現許可權校驗與日誌列印Spring
- ThinkPHP6 寫入日誌許可權報錯PHP
- Linux的許可權控制Linux
- Laravel實現許可權控制Laravel
- 許可權維持專題:域控制器許可權維持
- Java 訪問許可權控制(6)Java訪問許可權
- vue-router控制路由許可權Vue路由
- springboot-許可權控制shiro(二)Spring Boot
- etcd套路(四)auth許可權控制
- 資料分析的許可權控制
- Spring MVC 整合 Shiro 許可權控制SpringMVC
- spring2 Aop與事務、許可權管理Spring
- 一文讀懂 TKE 及 Kubernetes 訪問許可權控制訪問許可權
- k8s結合jumpserver做kubectl許可權控制 使用者在多個namespaces的訪問許可權 rbac許可權控制K8SServernamespace訪問許可權
- MYSQL學習筆記13: DCL許可權控制(使用者許可權操作)MySql筆記
- 一對一原始碼,前端頁面許可權和按鈕許可權控制原始碼前端
- 小知識:軟體開發的許可權控制和許可權驗證
- Spring Boot 之 RESRful API 許可權控制Spring BootAPI
- 使用nginx控制ElasticSearch訪問許可權NginxElasticsearch訪問許可權
- React基於RBAC的許可權控制React
- SAP Business Application Studio的許可權控制APP
- 打造自己的系統許可權控制
- casbin基於golang的許可權控制Golang
- Atlas 2.1.0 實踐(4)—— 許可權控制
- Android 採用AOP方式封裝6.0許可權管理Android封裝
- EMQX Enterprise 5.3 釋出:審計日誌、Dashboard 訪問許可權控制與 SSO 一站登入MQ訪問許可權