上一篇我根據框架中OAuth2.0的使用總結,畫了SSO單點登陸之OAuth2.0 登出流程,今天咱們看一下根據用戶token獲取yoghurt信息的流程:架構
/** * 根據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大型企業分佈式微服務雲架構源碼請加企鵝求求:一七九一七四三三八零負載均衡