OAuth2Realm.java 1.7 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 9 10
import org.apache.shiro.authz.AuthorizationInfo;
import org.apache.shiro.realm.AuthorizingRealm;
import org.apache.shiro.subject.PrincipalCollection;
Q
更新  
qinxiaodong@pannk.com 已提交
11
import org.springframework.beans.factory.annotation.Autowired;
Q
更新  
qinxiaodong@pannk.com 已提交
12 13 14 15 16 17 18
import org.springframework.stereotype.Component;

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

    @Autowired
    private RedisUtil redisUtil;

    /**
     * 授权
     *
     * @param principalCollection
     * @return
     */
Q
更新  
qinxiaodong@pannk.com 已提交
29 30
    @Override
    protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principalCollection) {
Q
更新  
qinxiaodong@pannk.com 已提交
31

Q
更新  
qinxiaodong@pannk.com 已提交
32 33 34
        return null;
    }

Q
更新  
qinxiaodong@pannk.com 已提交
35 36 37 38 39 40 41
    /**
     * 登录认证
     *
     * @param authenticationToken token
     * @return
     * @throws AuthenticationException
     */
Q
更新  
qinxiaodong@pannk.com 已提交
42 43
    @Override
    protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken authenticationToken) throws AuthenticationException {
Q
更新  
qinxiaodong@pannk.com 已提交
44 45 46 47 48 49 50 51 52
        String token = (String) authenticationToken.getPrincipal();
        SysUserEntity sysUserEntity = redisUtil.getEntity(Constant.USER_CACHE + token, SysUserEntity.class);
        if (sysUserEntity == null) {
            throw new BaseException("token失效,请重新登录");
        }
        if (sysUserEntity.getStatus() == 0) {
            throw new LockedAccountException("账号被锁定,清联系管理员处理");
        }
        return new SimpleAuthenticationInfo(sysUserEntity, token, getName());
Q
更新  
qinxiaodong@pannk.com 已提交
53 54
    }
}