上一篇我根據架構中OAuth2.0的使用總結,畫了一個根據使用者名+密碼實作OAuth2.0的登入認證的流程圖,今天我們看一下logout的流程:
/**
* 使用者登出
* @param accessToken
* @return
*/
@RequestMapping(value = "/user/logout", method = RequestMethod.POST)
public ResponseVO userLogout(@RequestHeader(value = "accessToken", required = true) String accessToken,
@RequestHeader(value = "userId", required = true) Long userId) throws Exception{
OauthAccessToken oauthAccessToken = userMgrService.getOauthAccessToken(accessToken);
if(null == oauthAccessToken){
return UserResponseCode.buildEnumResponseVO(UserResponseCode.RESPONSE_CODE_OAUTH_ACCESSTOKEN_EMPTY, null);
}
//刪除OauthToken記錄
boolean result = userMgrService.revokeOauthToken(oauthAccessToken);
if(result){
return UserResponseCode.buildEnumResponseVO(UserResponseCode.RESPONSE_RETURN_CODE_SUCCESS, null);
}
return UserResponseCode.buildEnumResponseVO(UserResponseCode.RESPONSE_CODE_SYSTEM_ERROR, null);
}
我這裡隻是簡單寫了一些登出的代碼,我們會在後面的文章中詳細貼出所有代碼供大家參考,而且會從建立資料庫,到執行操作的每一個流程記錄下來。
java B2B2C Springboot電子商城系統