上一篇我根據(jù)框架中OAuth2.0的使用總結(jié),畫(huà)了SSO單點(diǎn)登錄之OAuth2.0 登出流程,今天我們看一下根據(jù)用戶(hù)token獲取yoghurt信息的流程:
![]()
[backcolor=rgb(248, 248, 24 ]Java代碼 [color=rgb(16, 138, 19 ][url=] [/url]
- /**
- * 根據(jù)token獲取用戶(hù)信息
- * @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);
- }
-
- }
我這里只是簡(jiǎn)單寫(xiě)了一些登出的代碼,我們會(huì)在后面的文章中詳細(xì)貼出所有代碼供大家參考,而且會(huì)從創(chuàng)建數(shù)據(jù)庫(kù),到執(zhí)行操作的每一個(gè)流程記錄下來(lái)。
|