import java.util.HashSet; import java.util.Set; // 用户实体类 class User { private String username; private Set<Role> roles; public User(String username) { this.username = username; this.roles = new HashSet<>(); } public void addRole(Role role) { roles.add(role); } public boolean hasRole(String roleName) { for (Role role : roles) { if (role.getName().equals(roleName)) { return true; } } return false; } } // 角色实体类 class Role { private String name; private Set<Permission> permissions; public Role(String name) { this.name = name; this.permissions = new HashSet<>(); } public void addPermission(Permission permission) { permissions.add(permission); } public String getName() { return name; } } // 权限实体类 class Permission { private String name; public Permission(String name) { this.name = name; } public String getName() { return name; } } // 权限管理器类 class PermissionManager { public static void main(String[] args) { // 创建权限 Permission readPermission = new Permission("read"); Permission writePermission = new Permission("write"); Permission executePermission = new Permission("execute"); // 创建角色并分配权限 Role adminRole = new Role("admin"); adminRole.addPermission(readPermission); adminRole.addPermission(writePermission); adminRole.addPermission(executePermission); Role userRole = new Role("user"); userRole.addPermission(readPermission); // 创建用户并分配角色 User admin = new User("admin"); admin.addRole(adminRole); User user = new User("user"); user.addRole(userRole); // 检查用户是否具有特定权限 System.out.println("Admin has read permission: " + admin.hasRole("read")); // true System.out.println("User has write permission: " + user.hasRole("write")); // false } }
这个示例中,我们定义了三个实体类:User
、Role
和Permission
。User
类包含一个用户名和一个角色集合,Role
类包含一个角色名和一个权限集合,Permission
类包含一个权限名,我们还定义了一个PermissionManager
类,用于创建权限、角色和用户,并为它们分配相应的权限和角色,我们检查用户是否具有特定的权限。
以上内容就是解答有关权限管理java源码的详细内容了,我相信这篇文章可以为您解决一些疑惑,有任何问题欢迎留言反馈,谢谢阅读。
原创文章,作者:未希,如若转载,请注明出处:https://www.kdun.com/ask/1108284.html
本网站发布或转载的文章及图片均来自网络,其原创性以及文中表达的观点和判断不代表本网站。如有问题,请联系客服处理。
发表回复