OAuth2Realm.java 2.2 KB
Newer Older
Q
qinxiaodong@pannk.com 已提交
1
package com.pannk.mms.common.oauth2;
Q
更新  
qinxiaodong@pannk.com 已提交
2

Q
更新  
qinxiaodong@pannk.com 已提交
3 4 5 6 7
import com.pannk.mms.common.base.Constant;
import com.pannk.mms.common.exception.BaseException;
import com.pannk.mms.common.utils.RedisUtil;
import com.pannk.mms.modules.sys.entity.SysUserEntity;
import org.apache.shiro.authc.*;
Q
更新  
qinxiaodong@pannk.com 已提交
8
import org.apache.shiro.authz.AuthorizationInfo;
Q
qinxiaodong@pannk.com 已提交
9
import org.apache.shiro.authz.SimpleAuthorizationInfo;
Q
更新  
qinxiaodong@pannk.com 已提交
10 11
import org.apache.shiro.realm.AuthorizingRealm;
import org.apache.shiro.subject.PrincipalCollection;
Q
更新  
qinxiaodong@pannk.com 已提交
12
import org.springframework.beans.factory.annotation.Autowired;
Q
更新  
qinxiaodong@pannk.com 已提交
13 14
import org.springframework.stereotype.Component;

Q
qinxiaodong@pannk.com 已提交
15 16
import java.util.Set;

Q
更新  
qinxiaodong@pannk.com 已提交
17 18 19 20 21
/**
 * Created by wolf on 20-11-6.
 */
@Component
public class OAuth2Realm extends AuthorizingRealm {
Q
更新  
qinxiaodong@pannk.com 已提交
22 23 24 25

    @Autowired
    private RedisUtil redisUtil;

Q
qinxiaodong@pannk.com 已提交
26 27 28 29 30
    @Override
    public boolean supports(AuthenticationToken token) {
        return token instanceof OAuth2Token;
    }

Q
更新  
qinxiaodong@pannk.com 已提交
31 32 33 34 35 36
    /**
     * 授权
     *
     * @param principalCollection
     * @return
     */
Q
更新  
qinxiaodong@pannk.com 已提交
37 38
    @Override
    protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principalCollection) {
Q
qinxiaodong@pannk.com 已提交
39 40 41 42 43
        SysUserEntity sysUserEntity = (SysUserEntity) principalCollection.getPrimaryPrincipal();
        Set<String> perms = redisUtil.getEntity(Constant.PERMS_CAHCE + sysUserEntity.getId(), Set.class);
        SimpleAuthorizationInfo info = new SimpleAuthorizationInfo();
        info.setStringPermissions(perms);
        return info;
Q
更新  
qinxiaodong@pannk.com 已提交
44 45
    }

Q
更新  
qinxiaodong@pannk.com 已提交
46 47 48 49 50 51 52
    /**
     * 登录认证
     *
     * @param authenticationToken token
     * @return
     * @throws AuthenticationException
     */
Q
更新  
qinxiaodong@pannk.com 已提交
53 54
    @Override
    protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken authenticationToken) throws AuthenticationException {
Q
更新  
qinxiaodong@pannk.com 已提交
55 56 57 58 59
        String token = (String) authenticationToken.getPrincipal();
        SysUserEntity sysUserEntity = redisUtil.getEntity(Constant.USER_CACHE + token, SysUserEntity.class);
        if (sysUserEntity == null) {
            throw new BaseException("token失效,请重新登录");
        }
Q
qinxiaodong@pannk.com 已提交
60
        if (sysUserEntity.getStatus() == 1) {
Q
更新  
qinxiaodong@pannk.com 已提交
61 62 63
            throw new LockedAccountException("账号被锁定,清联系管理员处理");
        }
        return new SimpleAuthenticationInfo(sysUserEntity, token, getName());
Q
更新  
qinxiaodong@pannk.com 已提交
64 65
    }
}