SaConfig.java 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. package com.nb.auth.sa;
  2. import cn.dev33.satoken.SaManager;
  3. import cn.dev33.satoken.annotation.*;
  4. import cn.dev33.satoken.basic.SaBasicUtil;
  5. import cn.dev33.satoken.dao.SaTokenDaoRedisJackson;
  6. import cn.dev33.satoken.exception.NotPermissionException;
  7. import cn.dev33.satoken.stp.StpLogic;
  8. import cn.dev33.satoken.strategy.SaStrategy;
  9. import cn.hutool.core.util.StrUtil;
  10. import com.nb.auth.enums.StpTypeEnum;
  11. import com.nb.auth.utils.SecurityUtil;
  12. import lombok.AllArgsConstructor;
  13. import org.springframework.stereotype.Component;
  14. import javax.annotation.PostConstruct;
  15. import java.util.regex.Pattern;
  16. /**
  17. * @author lifang
  18. * @version 1.0.0
  19. * @ClassName SaConfig.java
  20. * @Description TODO
  21. * @createTime 2022年03月15日 16:51:00
  22. */
  23. @Component
  24. @AllArgsConstructor
  25. public class SaConfig {
  26. private final SaTokenDaoRedisJackson saTokenDaoRedisJackson;
  27. private final DefaultSaTokenListener defaultSaTokenListener;
  28. @PostConstruct
  29. public void init(){
  30. SaStrategy.me.hasElement=(list,element)->{
  31. // 空集合直接返回false
  32. if(list == null || list.size() == 0) {
  33. return false;
  34. }
  35. // 先尝试一下简单匹配,如果可以匹配成功则无需继续模糊匹配
  36. if (list.contains(element)) {
  37. return true;
  38. }
  39. // 开始模糊匹配
  40. for (String patt : list) {
  41. if(vagueMatch(patt, element)) {
  42. return true;
  43. }
  44. }
  45. // 走出for循环说明没有一个元素可以匹配成功
  46. return false;
  47. };
  48. SaStrategy.me.checkElementAnnotation=target->{
  49. // 校验 @SaCheckLogin 注解
  50. SaCheckLogin checkLogin = (SaCheckLogin) SaStrategy.me.getAnnotation.apply(target, SaCheckLogin.class);
  51. if(checkLogin != null) {
  52. SaManager.getStpLogic(checkLogin.type()).checkByAnnotation(checkLogin);
  53. }
  54. // 校验 @SaCheckRole 注解
  55. SaCheckRole checkRole = (SaCheckRole) SaStrategy.me.getAnnotation.apply(target, SaCheckRole.class);
  56. if(checkRole != null) {
  57. SaManager.getStpLogic(checkRole.type()).checkByAnnotation(checkRole);
  58. }
  59. // 校验 @SaCheckPermission 注解
  60. SaCheckPermission checkPermission = (SaCheckPermission) SaStrategy.me.getAnnotation.apply(target, SaCheckPermission.class);
  61. if(checkPermission != null) {
  62. String type= StrUtil.isBlankIfStr(checkPermission.type())?"login":checkPermission.type();
  63. StpLogic stpLogic = SecurityUtil.getStpLogic();
  64. if (!type.equals(stpLogic.getLoginType())) {
  65. throw new NotPermissionException("无权限访问此体系接口");
  66. }
  67. SaManager.getStpLogic(checkPermission.type()).checkByAnnotation(checkPermission);
  68. }
  69. // 校验 @SaCheckSafe 注解
  70. SaCheckSafe checkSafe = (SaCheckSafe) SaStrategy.me.getAnnotation.apply(target, SaCheckSafe.class);
  71. if(checkSafe != null) {
  72. SaManager.getStpLogic(checkSafe.type()).checkByAnnotation(checkSafe);
  73. }
  74. // 校验 @SaCheckBasic 注解
  75. SaCheckBasic checkBasic = (SaCheckBasic) SaStrategy.me.getAnnotation.apply(target, SaCheckBasic.class);
  76. if(checkBasic != null) {
  77. SaBasicUtil.check(checkBasic.realm(), checkBasic.account());
  78. }
  79. };
  80. // SaManager.setSaTokenContext();
  81. // SaManager.setSaTokenAction(new SaTokenActionDefaultImpl());
  82. SaManager.setSaTokenDao(saTokenDaoRedisJackson);
  83. // SaManager.setSaTokenListener(defaultSaTokenListener);
  84. StpTypeEnum[] values = StpTypeEnum.values();
  85. for (StpTypeEnum value : values) {
  86. SaManager.putStpLogic(new StpLogic(value.getText()));
  87. }
  88. }
  89. /**
  90. * 字符串模糊匹配
  91. * <p>example:
  92. * <p> user-add user* -- true
  93. * <p> art-add user* -- false
  94. * @param patt 表达式
  95. * @param str 待匹配的字符串
  96. * @return 是否可以匹配
  97. */
  98. public static boolean vagueMatch(String patt, String str) {
  99. // 如果表达式不带有*号,则只需简单equals即可 (速度提升200倍)
  100. if(!str.contains("*")&&!patt.contains("*")) {
  101. return patt.equals(str);
  102. }
  103. return Pattern.matches(str.replaceAll("\\*", ".*"), patt)||Pattern.matches(patt.replaceAll("\\*", ".*"), str);
  104. }
  105. }