許可權控制及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
相關文章
- Spring 使用Aop 做切面日誌,和許可權。Spring
- spring aop實現許可權控制,路徑控制Spring
- 關於 Laravel 日誌許可權Laravel
- Laravel Daily 日誌許可權問題LaravelAI
- 什麼是AOP系列之二:AOP與許可權控制實現(轉)
- Laravel 框架的日誌許可權問題Laravel框架
- Laravel 日誌檔案許可權問題Laravel
- Laravel 日誌有時候有許可權有時候沒有許可權?Laravel
- SpringBoot(一) 如何實現AOP的許可權控制Spring Boot
- spring aop實現簡單的許可權控制功能Spring
- Elasticsearch 許可權控制Elasticsearch
- artisan日誌 root 許可權解決辦法
- 如何用 Vue 實現前端許可權控制(路由許可權 + 檢視許可權 + 請求許可權)Vue前端路由
- 記一次 Laravel日誌許可權許可權問題(定時器導致)Laravel定時器
- Linux許可權控制Linux
- Appfuse:許可權控制APP
- ThinkPHP6 寫入日誌許可權報錯PHP
- SpringSecurity許可權管理系統實戰—八、AOP 記錄使用者、異常日誌SpringGse
- spring aop實現許可權管理Spring
- 事務日誌傳送使用者許可權設定及配置(2篇)
- Laravel實現許可權控制Laravel
- mysql 許可權控制筆記MySql筆記
- oracle列級許可權控制Oracle
- Linux的許可權控制Linux
- .NET 程式許可權控制、獲得管理員許可權程式碼
- SpringAop實現許可權校驗與日誌列印Spring
- Android許可權管理之Permission許可權機制及使用Android
- 資料分析的許可權控制
- Java 訪問許可權控制(6)Java訪問許可權
- vue-router控制路由許可權Vue路由
- 下載許可權控制機制
- 資料安全之許可權控制
- Solaris下控制ftp的許可權FTP
- 控制DDL許可權及紀錄DDL操作的Trigger
- Android 安全架構及許可權控制機制剖析Android架構
- Oracle的物件許可權、角色許可權、系統許可權Oracle物件
- spring2 Aop與事務、許可權管理Spring
- 提問:使用spring aop實現許可權管理Spring