(十三)企業級java b2bc商城系統開源源碼二次開發-SSO單點登陸之OAuth2.0 根據token獲取用戶信息(4)

上一篇我根據框架中OAuth2.0的使用總結,畫了SSO單點登陸之OAuth2.0 登出流程,今天咱們看一下根據用戶token獲取yoghurt信息的流程:架構

50794a46-b86e-3062-8768-2b20627aec29.png

/** 
 * 根據token獲取用戶信息 
 * @param accessToken 
 * @return 
 * @throws Exception 
 */  
@RequestMapping(value = "/user/token/{accesstoken}", method = RequestMethod.GET)  
public ResponseVO getUserByToken(@PathVariable(value = "accessToken", required = true) String accessToken,@RequestHeader(value = "userId", required = true) Long userId) throws Exception {  
    if(StringUtils.isEmpty(accessToken)){  
        return UserResponseCode.buildEnumResponseVO(UserResponseCode.RESPONSE_CODE_REQ_CANNOT_EMPTY, null);  
    }  
      
    OauthAccessToken oauthAccessToken = userMgrService.getOauthAccessToken(accessToken);  
    if(null == oauthAccessToken){  
        return UserResponseCode.buildEnumResponseVO(UserResponseCode.RESPONSE_CODE_OAUTH_ACCESSTOKEN_EMPTY, null);  
    }  
      
    String userName = oauthAccessToken.getUserName();  
    if (StringUtils.isEmpty(userName)) {  
        return UserResponseCode.buildEnumResponseVO(UserResponseCode.RESPONSE_CODE_OAUTH_ACCESSTOKEN_EMPTY, null);  
    }  
      
    return this.getUser(userName);  
}  
  
       @RequestMapping(path = "/user/get/{userName}", method = RequestMethod.GET)  
public ResponseVO getUser(@PathVariable(value = "userName") String userName) {  
    Map<String, Object> returnData = null;  
    try {  
        User user = userMgrService.getUserByName(userName);  
        if (null != user) {  
            returnData = new HashMap<String, Object>();  
            returnData.put("user", user);  
            return UserResponseCode.buildEnumResponseVO(UserResponseCode.RESPONSE_CODE_SUCCESS, returnData);  
        }  
        return UserResponseCode.buildEnumResponseVO(UserResponseCode.RESPONSE_CODE_SYSTEM_ERROR, null);  
    } catch (Exception e) {  
        return UserResponseCode.buildEnumResponseVO(UserResponseCode.RESPONSE_CODE_SYSTEM_ERROR, null);  
    }  
      
}

能夠看到這裏,咱們除了去掉了原來與LoadBalancerClient相關的邏輯以外,對於RestTemplate的使用,咱們的第一個url參數有一些特別。這裏請求的host位置並無使用一個具體的IP地址和端口的形式,而是採用了服務名的方式組成。那麼這樣的請求爲何能夠調用成功呢?由於Spring Cloud Ribbon有一個攔截器,它可以在這裏進行實際調用的時候,自動的去選取服務實例,並將實際要請求的IP地址和端口替換這裏的服務名,從而完成服務接口的調用。app

在完成了上面你的代碼編寫以後,讀者能夠將eureka-server、eureka-client、eureka-consumer-ribbon都啓動起來,而後訪問http://localhost:2101/consumer ,來跟蹤觀察eureka-consumer-ribbon服務是如何消費eureka-client服務的/dc接口的,而且也能夠經過啓動多個eureka-client服務來觀察其負載均衡的效果。Spring Cloud大型企業分佈式微服務雲架構源碼請加企鵝求求:一七九一七四三三八零負載均衡

相關文章
相關標籤/搜索