springsecurity中使access_token获取用户信息(tokenStore)

springsecurity中使access_token获取用户信息(tokenStore)

public class TokenUtil {
	/**
	 * 根据token获取用户名
	 *
	 *<hr>
	 * @author hanjidong
	 * @date 2020年12月16日 上午10:37:12
	 * @since 0.0.1
	 * @param access_token
	 * @return
	 * String
	 */
	public static SyswareUserDetails getUserNameByToken(String access_token) {
		try {
			//获取tokensotre对象
			InMemoryTokenStore tokenStore = (InMemoryTokenStore) SystemContext.getBean("tokenStore");
			OAuth2AccessToken readAccessToken = tokenStore.readAccessToken(access_token);
			if(readAccessToken == null){
				throw new IllegalArgumentException("token无效");
			}
			if(readAccessToken.isExpired()){
				throw new RuntimeException("token已过期");
			}
			OAuth2Authentication oAuth2Authentication = null;
			Field authenticationStore = tokenStore.getClass().getDeclaredField("authenticationStore");
			authenticationStore.setAccessible(true);
			Object authenticationStoreObj = authenticationStore.get(tokenStore);
			if (authenticationStoreObj instanceof ConcurrentHashMap) {
				ConcurrentHashMap<String, OAuth2Authentication> nticationStoreObjMap = (ConcurrentHashMap<String, OAuth2Authentication>) authenticationStoreObj;
				oAuth2Authentication = nticationStoreObjMap.get(access_token);
			}
			Object principal = oAuth2Authentication.getPrincipal();
			
			return (SyswareUserDetails) principal;
//			//获取存储用户名与token的map
//			// 暴力反射获取属性
//			Field declaredField = tokenStore.getClass().getDeclaredField("userNameToAccessTokenStore");
//			// 设置反射时取消Java的访问检查,暴力访问
//			declaredField.setAccessible(true);
//			Object nameObject = declaredField.get(tokenStore);
//			if (nameObject instanceof ConcurrentHashMap) {
//				ConcurrentHashMap<String, Collection<OAuth2AccessToken>> usernameTokenMap = (ConcurrentHashMap<String, Collection<OAuth2AccessToken>>) nameObject;
//				Set<Entry<String, Collection<OAuth2AccessToken>>> entrySet = usernameTokenMap.entrySet();
//				for (Entry<String, Collection<OAuth2AccessToken>> entry : entrySet) {
//					Collection<OAuth2AccessToken> value = entry.getValue();
//					for (OAuth2AccessToken oAuth2AccessToken : value) {
//						if (oAuth2AccessToken.getValue().equals(access_token)) {
//							return entry.getKey().split(":")[1];
//						}
//					}
//				}
//			}
		} catch (Exception e) {
			throw new RuntimeException(e.getMessage());
		}
	}
}
@Component
public class SystemContext implements ApplicationContextAware{
	/**
     * 上下文对象实例
     */
    private static ApplicationContext applicationContext;

    @SuppressWarnings("static-access")
	@Autowired
    public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
        this.applicationContext = applicationContext;
    }
    /**
     * 获取applicationContext
     * @return
     */
    public static ApplicationContext getApplicationContext() {
        return applicationContext;
    }
    /**
     * 通过name获取 Bean.
     * @param name
     * @return
     */
    public static Object getBean(String name){
        return getApplicationContext().getBean(name);
    }

    /**
     * 通过class获取Bean.
     * @param clazz
     * @param <T>
     * @return
     */
    public static <T> T getBean(Class<T> clazz){
        return getApplicationContext().getBean(clazz);
    }

    /**
     * 通过name,以及Clazz返回指定的Bean
     * @param name
     * @param clazz
     * @param <T>
     * @return
     */
    public static <T> T getBean(String name,Class<T> clazz){
        return getApplicationContext().getBean(name, clazz);
    }
}

 

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Spring Security OAuth2 Authorization Server 0.3.1中,可以通过实现TokenEnhancer接口来向Access Token中添加用户信息。具体步骤如下: 1. 创建一个类,实现TokenEnhancer接口,例如: ```java public class CustomTokenEnhancer implements TokenEnhancer { @Override public OAuth2AccessToken enhance(OAuth2AccessToken accessToken, OAuth2Authentication authentication) { Map<String, Object> additionalInfo = new HashMap<>(); additionalInfo.put("user_name", authentication.getName()); ((DefaultOAuth2AccessToken) accessToken).setAdditionalInformation(additionalInfo); return accessToken; } } ``` 上述代码中,我们向Access Token的附加信息中添加了一个名为"user_name"的键值对,它的值为当前用户的用户名。 2. 在Authorization Server配置类中,设置TokenEnhancer,例如: ```java @Configuration @EnableAuthorizationServer public class AuthorizationServerConfig extends AuthorizationServerConfigurerAdapter { @Autowired private AuthenticationManager authenticationManager; @Autowired private UserDetailsService userDetailsService; @Autowired private DataSource dataSource; @Override public void configure(AuthorizationServerEndpointsConfigurer endpoints) throws Exception { endpoints.authenticationManager(authenticationManager) .userDetailsService(userDetailsService) .tokenStore(tokenStore()) .tokenEnhancer(tokenEnhancer()); } @Bean public TokenEnhancer tokenEnhancer() { return new CustomTokenEnhancer(); } // ... } ``` 在上述代码中,我们通过调用tokenEnhancer()方法来设置TokenEnhancer,它使用我们自定义的CustomTokenEnhancer类。 3. 在调用/token接口时,通过获取Access Token的响应内容,可以看到"user_name"键值对的值已经被添加到Access Token的附加信息中。 以上就是向Access Token中添加用户信息的步骤。需要注意的是,如果要添加更多的用户信息,只需要在CustomTokenEnhancer类的enhance()方法中继续向additionalInfo中添加键值对即可。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值