久久国产成人av_抖音国产毛片_a片网站免费观看_A片无码播放手机在线观看,色五月在线观看,亚洲精品m在线观看,女人自慰的免费网址,悠悠在线观看精品视频,一级日本片免费的,亚洲精品久,国产精品成人久久久久久久

分享

一個(gè)接口優(yōu)雅的實(shí)現(xiàn) Spring Cloud OAuth2 自定義token返回格式

 woh5r1ofyffxnh 2023-03-03 發(fā)布于浙江
大家好,,我是不才陳某~

陳某的《Spring Cloud Alibaba實(shí)戰(zhàn)項(xiàng)目》 視頻教程已經(jīng)錄完了,涉及到Alibaba的各種中間件實(shí)戰(zhàn),,戳這里--->Spring Cloud Alibaba 實(shí)戰(zhàn) 視頻專欄 開放訂閱~

最近訂閱《Spring Cloud Alibaba 項(xiàng)目實(shí)戰(zhàn)》的朋友針對(duì)Spring Security OAuth2.0 想要陳某補(bǔ)充一些知識(shí),如下:

今天這篇文章就來(lái)回答其中一個(gè)問題:如何自定義token的返回格式,?

本篇文章對(duì)應(yīng)視頻,介紹更加詳細(xì):

問題描述

Spring Security OAuth的token返回格式都是默認(rèn)的,,但是往往這個(gè)格式是不適配系統(tǒng),,/oauth/token返回的格式如下:

{
    "access_token": token
    "token_type""bearer",
    "refresh_token": xxxx
    "expires_in": xxx,
    "scope""xxx",
    "jti": xxxx
    ....................
}

然而此時(shí)系統(tǒng)中的統(tǒng)一返回格式為:

{
    "code":xxx
    "data":xxx
    "msg":xxx
}

那么如何去對(duì)默認(rèn)的格式進(jìn)行修改呢?

解決方案

其實(shí)解決方案還是很多的,,據(jù)陳某了解有如下兩種解決方案:

  1. 使用AOP的方式對(duì)/oauth/token這個(gè)接口的結(jié)果攔截修改
  2. 重定義接口覆蓋默認(rèn)的

第一種方案呢可以實(shí)現(xiàn),,但是對(duì)于陳某來(lái)說不夠優(yōu)雅,實(shí)現(xiàn)比較簡(jiǎn)單,,不顯逼格

于是陳某今天介紹第二種方案,,一種比較優(yōu)雅的方式,;想要理解第二種方式必須對(duì)Spring Security的底層源碼有一些了解,。

/oauth/token這個(gè)接口定義在哪里呢?通過源碼我們知道定義在org.springframework.security.oauth2.provider.endpoint.TokenEndpoint中,,如下:

@RequestMapping(value = "/oauth/token", method=RequestMethod.GET)
public ResponseEntity<OAuth2AccessToken> getAccessToken(Principal principal, @RequestParam
Map<String, String> parameters)
 throws HttpRequestMethodNotSupportedException 
{}

@RequestMapping(value = "/oauth/token", method=RequestMethod.POST)
public ResponseEntity<OAuth2AccessToken> postAccessToken(Principal principal, @RequestParam
Map<String, String> parameters)
 throws HttpRequestMethodNotSupportedException 
{}

可以看到針對(duì)這個(gè)接口定義了兩個(gè),,一個(gè)是GET請(qǐng)求、一個(gè)是POST請(qǐng)求

TokenEndpoint其實(shí)就是一個(gè)接口,,使用注解@FrameworkEndpoint標(biāo)注,,這個(gè)注解和@Controller的作用一樣,如下:

@FrameworkEndpoint
public class TokenEndpoint extends AbstractEndpoint {}

那么知道在哪里定義的就好辦了,,模仿著它這個(gè)接口自己重新定義一個(gè)覆蓋掉不就好了,,如下:

@Api(value = "OAuth接口")
@RestController
@RequestMapping("/oauth")
@Slf4j
public class AuthController implements InitializingBean {

    //令牌請(qǐng)求的端點(diǎn)
    @Autowired
    private TokenEndpoint tokenEndpoint;

    //自定義異常翻譯器,針對(duì)用戶名,、密碼異常,,授權(quán)類型不支持的異常進(jìn)行處理
    private OAuthServerWebResponseExceptionTranslator translate;

    /**
     * 重寫/oauth/token這個(gè)默認(rèn)接口,返回的數(shù)據(jù)格式統(tǒng)一
     */

    @PostMapping(value = "/token")
    public ResultMsg<OAuth2AccessToken> postAccessToken(Principal principal, @RequestParam
            Map<String, String> parameters)
 throws HttpRequestMethodNotSupportedException 
{
        OAuth2AccessToken accessToken = tokenEndpoint.postAccessToken(principal, parameters).getBody();
        return ResultMsg.resultSuccess(accessToken);
    }
}

可以看到接口內(nèi)部不需要自己重寫邏輯,,只需要調(diào)用TokenEndpoint中的方法

注意:由于對(duì)TokenEndpoint中的端點(diǎn)重寫了,,因此前面定義的對(duì)用戶名、密碼之類的異常捕獲的翻譯類(OAuthServerWebResponseExceptionTranslator)將會(huì)失效,,需要在全局異常中進(jìn)行捕獲

上面是/oauth/token的接口,,/oauth/check_token這個(gè)校驗(yàn)token的接口如需自定義也是可以的,對(duì)應(yīng)的類是org.springframework.security.oauth2.provider.endpoint.CheckTokenEndpoint

重寫后代碼如下:

@Api(value = "OAuth接口")
@RestController
@RequestMapping("/oauth")
@Slf4j
public class AuthController implements InitializingBean {

    @Autowired
    private CheckTokenEndpoint checkTokenEndpoint;

    //自定義異常翻譯器,,針對(duì)用戶名,、密碼異常,授權(quán)類型不支持的異常進(jìn)行處理
    private OAuthServerWebResponseExceptionTranslator translate;
    
    /**
     * 重寫/oauth/check_token這個(gè)默認(rèn)接口,,用于校驗(yàn)令牌,,返回的數(shù)據(jù)格式統(tǒng)一
     */

    @PostMapping(value = "/check_token")
    public ResultMsg<Map<String,?>> checkToken(@RequestParam("token") String value)  {
        Map<String, ?> map = checkTokenEndpoint.checkToken(value);
        return ResultMsg.resultSuccess(map);
    }

這種方式是不是很優(yōu)雅,?也很符合Spring Security的設(shè)計(jì)思想,AOP的方式還要對(duì)參數(shù)解析,,重新包裝

好了,,關(guān)于測(cè)試的話自己搞一搞

總結(jié)

本篇文章介紹了認(rèn)證服務(wù)中對(duì)token的返回格式自定義,總的來(lái)說還是比較簡(jiǎn)單的,,有興趣的也可以去網(wǎng)上找找關(guān)于AOP的方式,。


陳某的知識(shí)星球(點(diǎn)擊加入)正式上線了,在星球內(nèi)部你可以看陳某的 已出(兩個(gè)) 的和未來(lái)待出的所有視頻教程(持續(xù)進(jìn)階,、實(shí)戰(zhàn)),,向陳某提問、跟著陳某制定的學(xué)習(xí)線路向技術(shù)專家進(jìn)階

另外,,如果你最近想跳槽的話可以點(diǎn)擊這里領(lǐng)取,!BAT大廠面試真題

如果這篇文章對(duì)你有所幫助,或者有所啟發(fā)的話,,幫忙點(diǎn)贊,、在看轉(zhuǎn)發(fā),、收藏,,你的支持就是我堅(jiān)持下去的最大動(dòng)力!

    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多