@RefreshScope @Configuration public class CasConfiguration extends CasClientConfigurerAdapter { private final static Logger log = LoggerFactory.getLogger(CasConfiguration.class); @Autowired private CasProperties casProperties; @Autowired(required = false) private DebugUserService debugUserService; @Override public void configureAuthenticationFilter(FilterRegistrationBean authenticationFilter) { super.configureAuthenticationFilter(authenticationFilter); if (casProperties.getUrlPatterns() != null) { authenticationFilter.setUrlPatterns(casProperties.getUrlPatterns()); } else { log.warn("没有设置gate.cas.url-patterns,使用: [/*]"); authenticationFilter.setUrlPatterns(Collections.singletonList("/*")); } AuthenticationFilter authFilter = (AuthenticationFilter) authenticationFilter.getFilter(); authFilter.setIgnoreUrlPatternMatcherStrategyClass(new UrlPatternMatcherStrategy() { @Override public boolean matches(String s) { // s: http://JCODE-PC.lan:8080/actuator/health // s: http://localhost:8080/test // 开启调试时忽略所有拦截 if (debugUserService != null && debugUserService.inDebugMode()) { return true; } return ignoreUrlPatterns(s); } @Override public void setPattern(String s) { log.debug("CAS UrlPatternMatcherStrategy set pattern: {}", s); } }); } public boolean ignoreUrlPatterns(String requestUri) { List<String> ignoreUrlPatterns = casProperties.getIgnoreUrlPatterns();//忽略包括哪些路径 if (ignoreUrlPatterns.size() == 0) { return false; } for (String pattern : ignoreUrlPatterns) { if (requestUri.contains(pattern)) { return true; } } return false; } }详解该代码
时间: 2024-03-29 18:34:26 浏览: 14
这段代码是一个基于Spring Boot框架的Cas客户端配置类,其中使用了@Configuration和@RefreshScope注解来标识这是一个配置类,并且支持动态刷新配置。该类继承了CasClientConfigurerAdapter类,覆盖了其中的configureAuthenticationFilter()方法,来配置Cas客户端的认证过滤器。
在该方法中,首先通过@Autowired注解注入了CasProperties和DebugUserService两个类的实例,用于读取Cas客户端的配置和判断是否处于调试模式。然后根据CasProperties中配置的URL路径模式,设置了认证过滤器的URL路径。
接下来,该方法使用了一个匿名内部类来实现了UrlPatternMatcherStrategy接口,来判断是否忽略某些URL路径,如果debugUserService不为空且处于调试模式,则忽略所有拦截。最后,该类还提供了一个ignoreUrlPatterns()方法,用于判断是否忽略某些URL路径。
相关问题
@Controller @RequestMapping("/payLogs") public class PayLogsController extends BaseController { protected static final Logger Log = LoggerFactory.getLogger(PayLogsController.class); @Autowired private CacheHandle cacheHandle; @Autowired private UsersService usersService; @Autowired private PayLogsService payLogsService; @RequestMapping("") public String index() { return "pages/PayLogs"; }
这是一个使用 Spring MVC 框架开发的 Java 后端控制器,用于处理支付记录相关的请求。该控制器使用 @Controller 注解,表示它是一个控制器类;使用 @RequestMapping 注解,表示该控制器处理的请求路径是 /payLogs。
该控制器有三个成员变量,分别是 CacheHandle、UsersService 和 PayLogsService。CacheHandle 用于管理缓存,UsersService 用于管理用户信息,PayLogsService 用于管理支付记录。
该控制器有一个处理 GET 请求的方法,使用 @RequestMapping 注解,并且没有指定具体的请求路径,表示处理的是 /payLogs 这个路径的 GET 请求。该方法返回一个字符串 "pages/PayLogs",表示需要渲染名为 PayLogs 的页面。
由于该方法没有使用 @ResponseBody 注解,因此它会将返回值作为视图名称,传递给视图解析器进行解析。在 Spring MVC 中,视图解析器会将视图名称解析为具体的视图文件路径,然后将该视图文件渲染成 HTML 页面并返回给客户端。
@Controller @RequestMapping("/notices") public class NoticesController extends BaseController { protected static final Logger Log = LoggerFactory.getLogger(NoticesController.class); @Autowired private CacheHandle cacheHandle; @Autowired private NoticesService noticesService; @Autowired private UsersService usersService; @RequestMapping("") public String index() { return "pages/Notices"; } @GetMapping("/info") @ResponseBody public R getInfo(String id) { Log.info("查找指定通知记录,ID:{}", id); Notices notices = noticesService.getOne(id); return R.successData(notices); }
这是一个使用 Spring MVC 框架开发的 Java 后端控制器,用于处理通知相关的请求。该控制器使用 @Controller 注解,表示它是一个控制器类;使用 @RequestMapping 注解,表示该控制器处理的请求路径是 /notices。
该控制器有三个成员变量,分别是 CacheHandle、NoticesService 和 UsersService。CacheHandle 用于管理缓存,NoticesService 用于管理通知信息,UsersService 用于管理用户信息。
该控制器有一个处理 GET 请求的方法,使用 @RequestMapping 注解,并且没有指定具体的请求路径,表示处理的是 /notices 这个路径的 GET 请求。该方法返回一个字符串 "pages/Notices",表示需要渲染名为 Notices 的页面。
另外,该控制器还有一个处理 GET 请求的方法,使用 @GetMapping 注解,并且指定请求路径为 /info。该方法接受一个名为 id 的字符串参数,表示需要查找的通知记录的 ID。该方法使用 @ResponseBody 注解,将返回值以 JSON 格式输出。
该方法首先记录了一条日志,表示正在查找指定的通知记录。然后使用 noticesService.getOne(id) 方法查找指定 ID 的通知记录,并将其封装为一个 R 对象返回。如果查找成功,则 R 对象的状态为成功,并且使用 successData 方法将通知记录作为数据返回。如果查找失败,则 R 对象的状态为失败,并且使用 fail 方法返回失败信息。