UserRealm.java 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. package com.pine.admin.shiro;
  2. import com.alibaba.fastjson.JSON;
  3. import com.alibaba.fastjson.JSONObject;
  4. import com.pine.admin.modules.business.entity.UserInfo;
  5. import com.pine.admin.modules.business.service.UserInfoService;
  6. import com.pine.admin.modules.system.entity.SysPermission;
  7. import com.pine.admin.modules.system.entity.SysUser;
  8. import com.pine.admin.modules.system.service.SysPermissionService;
  9. import com.pine.admin.modules.system.service.SysService;
  10. import com.pine.admin.modules.system.service.SysUserService;
  11. import com.pine.common.dto.Result;
  12. import com.pine.common.utils.Constant;
  13. import com.pine.common.utils.RSAUtils;
  14. import org.apache.commons.lang.RandomStringUtils;
  15. import org.apache.commons.lang.StringUtils;
  16. import org.apache.shiro.SecurityUtils;
  17. import org.apache.shiro.authc.*;
  18. import org.apache.shiro.authc.credential.CredentialsMatcher;
  19. import org.apache.shiro.authc.credential.HashedCredentialsMatcher;
  20. import org.apache.shiro.authz.AuthorizationInfo;
  21. import org.apache.shiro.authz.SimpleAuthorizationInfo;
  22. import org.apache.shiro.realm.AuthorizingRealm;
  23. import org.apache.shiro.session.Session;
  24. import org.apache.shiro.subject.PrincipalCollection;
  25. import org.apache.shiro.subject.SimplePrincipalCollection;
  26. import org.apache.shiro.subject.support.DefaultSubjectContext;
  27. import org.apache.shiro.util.ByteSource;
  28. import org.apache.shiro.web.mgt.DefaultWebSecurityManager;
  29. import org.apache.shiro.web.session.mgt.DefaultWebSessionManager;
  30. import org.springframework.beans.factory.annotation.Autowired;
  31. import org.springframework.context.annotation.Lazy;
  32. import org.springframework.stereotype.Component;
  33. import java.util.*;
  34. import java.util.stream.Collectors;
  35. @Component
  36. public class UserRealm extends AuthorizingRealm {
  37. @Autowired
  38. @Lazy
  39. private SysService sysService;
  40. /**
  41. * 添加用户权限
  42. *
  43. * @param principals
  44. * @return
  45. */
  46. @Override
  47. protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principals) {
  48. return null;
  49. }
  50. /**
  51. * 验证用户名密码
  52. *
  53. * @param token
  54. * @return
  55. */
  56. @Override
  57. protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken token) throws AuthenticationException {
  58. //若为经销商
  59. String dealerInfo = (String) token.getPrincipal();
  60. ShiroUserInfo shiroUserInfo = JSONObject.parseObject(dealerInfo, ShiroUserInfo.class);
  61. /**
  62. * 设置权限
  63. */
  64. String password = ShiroUtils.sha256(Constant.USER_PASSWORD, Constant.USER_SALT);
  65. return new SimpleAuthenticationInfo(shiroUserInfo, password, ByteSource.Util.bytes(Constant.USER_SALT), getName());
  66. }
  67. @Override
  68. public void setCredentialsMatcher(CredentialsMatcher credentialsMatcher) {
  69. HashedCredentialsMatcher shaCredentialsMatcher = new HashedCredentialsMatcher();
  70. shaCredentialsMatcher.setHashAlgorithmName(ShiroUtils.hashAlgorithmName);
  71. shaCredentialsMatcher.setHashIterations(ShiroUtils.hashIterations);
  72. super.setCredentialsMatcher(shaCredentialsMatcher);
  73. }
  74. }