zoukankan      html  css  js  c++  java
  • 本地缓存

    一些间的使用

    @Bean
        public LoadingCache<String, OAuth2Authentication> authenticationLoadingCache() {
            return CacheBuilder.newBuilder().maximumSize(1000L).expireAfterWrite((long)this.oAuth2ClientProperties.getExpireAfterWrite().intValue(), TimeUnit.SECONDS).refreshAfterWrite((long)this.oAuth2ClientProperties.getRefreshAfterWrite().intValue(), TimeUnit.SECONDS).build(new CacheLoader<String, OAuth2Authentication>() {
                public OAuth2Authentication load(String jwtToken) throws Exception {
                    ResponseMessage<OAuth2Authentication> responseMessage = OAuth2ClientAutoConfiguration.this.oAuth2ResourceService.getLoginUserByJwt(OAuth2ClientAutoConfiguration.this.oAuth2UtilService.buildJwtQueryParam(jwtToken));
                    if (!responseMessage.is2xxSuccessful()) {
                        return null;
                    } else {
                        OAuth2Authentication oAuth2Authentication = (OAuth2Authentication)responseMessage.getResult(OAuth2Authentication.class);
                        return oAuth2Authentication;
                    }
                }
            });
        }
    
    
        @Autowired
        LoadingCache<String, OAuth2Authentication> authenticationLoadingCache;
    
        if (this.authenticationLoadingCache.getIfPresent(authToken) == null) {
                            ResponseMessage<Object> claims = this.oAuth2AccessTokenService.checkToken(authToken);
                            if ("-1".equals(claims.getCode())) {
                                throw new CommonException(401, claims.getMessage());
                            }
         }
    
        if (SecurityContextHolder.getContext().getAuthentication() == null || !SecurityContextHolder.getContext().getAuthentication().getCredentials().equals(username)) {
                            OAuth2Authentication oAuth2Authentication = (OAuth2Authentication)this.authenticationLoadingCache.getUnchecked(authToken);
                            AuthUserDetails principal = new AuthUserDetails(oAuth2Authentication);
                            PreAuthenticatedAuthenticationToken auth = new PreAuthenticatedAuthenticationToken(principal, authToken, principal.getAuthorities());
                            SecurityContextHolder.getContext().setAuthentication(auth);
         }
    
  • 相关阅读:
    Oracle ref cursor和sys_refcursor
    一些命令可以帮您了解Linux 操作系统用户信息
    Linux 6上使用UDEV绑定共享存储
    Oracle VirtualBox 问题汇总
    Linux 常用操作
    CentOS 7 运行级别切换
    Oracle 更新Opatch、打补丁
    django rest framework restful 规范
    CBV FBV rest framework
    CRM
  • 原文地址:https://www.cnblogs.com/liuyupen/p/11131808.html
Copyright © 2011-2022 走看看