1 前言
上一章我们搭建好了授权认证服务器,也能成功返回token了,oauth2默认的格式如下:
{
"access_token": "86d17c41-4de9-470a-a637-0acb7237099d",
"token_type": "bearer",
"refresh_token": "fb255411-9535-47ad-9f7e-40b21fac42cf",
"expires_in": 43199,
"scope": "all"
}
但是一般前后端交互时有关于API数据格式的约定,现在我想以如下格式来返回token:
{
"code": 0,
"msg": "登录成功!",
"data": {
"access_token": "86d17c41-4de9-470a-a637-0acb7237099d",
"token_type": "bearer",
"refresh_token": "fb255411-9535-47ad-9f7e-40b21fac42cf",
"expires_in": 43097,
"scope": "all"
}
}
期间我也参考了很多其它资料,比如https://blog.youkuaiyun.com/u013905744/article/details/100637224,这篇文章使用切面编程的方式将/oauth/token接口返回的数据重新封装,这个方法我觉得有点麻烦,所以没有试过。另外还有https://segmentfault.com/a/1190000020317220?utm_source=tag-newest,这篇文章使用的方法是重写/oauth/token接口,直接调用TokenEndpoint的postAccessToken方法获取 token然后重新包装,这个方法我试过了,可以用,但是有点问题,用这种方法时异常处理有点问题,具体就不多说了。
在查资料的过程中,也看到别人发的问题贴子,需求跟我一样,但是下面的回答没有具体的代码,只是有一段话,说可以后端转发请求到/oauth/token,拿到结果再进行封装。我觉得这种方法应该是可行的,于是有了下文的具体实现,现在放上干货。
2 自定义token返回格式
与前端约定格式如下:
{
"code":0,//表示成功
"msg":"",//信息
"data":{
//数据
}
}
因此我们写一个ResponseResult 工具类来返回数据,代码如下:
package com.example.oauth2.util;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data
@NoArgsConstructor
@AllArgsConstructor
public class ResponseResult {
//返回状态码
private int code;
//返回信息
private String msg;
//返回数据
private Object data;
public ResponseResult(Object data){
this.code=0;
this.msg="操作成功!";
this.data=data;
}
public ResponseResult(String msg,Object data){
this.code=0;
this.msg=msg;<