ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

CrmRealm

2020-12-05 16:03:48  阅读:147  来源: 互联网

标签:CrmRealm simpleAuthorizationInfo employee org apache import shiro


package cn.wolfcode.realm;

import cn.wolfcode.domain.Employee;
import cn.wolfcode.domain.Role;
import cn.wolfcode.mapper.EmployeeMapper;
import cn.wolfcode.mapper.PermissionMapper;
import cn.wolfcode.mapper.RoleMapper;
import org.apache.shiro.authc.AuthenticationException;
import org.apache.shiro.authc.AuthenticationInfo;
import org.apache.shiro.authc.AuthenticationToken;
import org.apache.shiro.authc.SimpleAuthenticationInfo;
import org.apache.shiro.authc.credential.CredentialsMatcher;
import org.apache.shiro.authz.AuthorizationInfo;
import org.apache.shiro.authz.SimpleAuthorizationInfo;
import org.apache.shiro.realm.AuthorizingRealm;
import org.apache.shiro.subject.PrincipalCollection;
import org.apache.shiro.util.ByteSource;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import java.util.ArrayList;
import java.util.List;

@Component
public class CrmRealm extends AuthorizingRealm {

@Autowired
private RoleMapper roleMapper;
@Autowired
private EmployeeMapper employeeMapper;
@Autowired
private PermissionMapper permissionMapper;

@Autowired
@Override
public void setCredentialsMatcher(CredentialsMatcher credentialsMatcher) {
super.setCredentialsMatcher(credentialsMatcher);
}

@Override
protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principals) {
SimpleAuthorizationInfo simpleAuthorizationInfo = new SimpleAuthorizationInfo();
Employee employee = (Employee) principals.getPrimaryPrincipal();
if (employee.isAdmin()) {
simpleAuthorizationInfo.addRole("admin");
simpleAuthorizationInfo.addStringPermission("*:*");
return simpleAuthorizationInfo;
}
List<Role> roleList = roleMapper.selectByEmployeeId(employee.getId());
if (roleList.iterator().hasNext() && roleList.iterator().next() == null) {
List<String> list = new ArrayList<>();
for (Role role : roleList) {
list.add(role.getSn());
}
simpleAuthorizationInfo.addRoles(list);
List<String> expression = permissionMapper.selectExperssionByCurrentUserId(employee.getId());
if (expression.iterator().hasNext() && expression.iterator().next() == null) {
simpleAuthorizationInfo.addStringPermissions(expression);
}
}
return simpleAuthorizationInfo;
}

@Override
protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken token) throws AuthenticationException {
String username = (String) token.getPrincipal();
Employee employee = employeeMapper.selectByname(username);
if (employee != null) {
SimpleAuthenticationInfo simpleAuthenticationInfo = new SimpleAuthenticationInfo(employee, employee.getPassword(), ByteSource.Util.bytes(employee.getName()), this.getName());
return simpleAuthenticationInfo;
} else {
return null;

}

}
}

标签:CrmRealm,simpleAuthorizationInfo,employee,org,apache,import,shiro
来源: https://www.cnblogs.com/Moon-Yty/p/14089961.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有