mirror of
https://gitee.com/durcframework/SOP.git
synced 2025-08-11 12:56:28 +08:00
53 lines
1.6 KiB
Markdown
53 lines
1.6 KiB
Markdown
# 自定义校验token
|
||
|
||
在`@Open`注解中有一个属性`needToken`,用来告诉网关是否校验token
|
||
|
||
```java
|
||
/**
|
||
* 是否需要appAuthToken,设置为true,网关端会校验token是否存在
|
||
*/
|
||
boolean needToken() default false;
|
||
```
|
||
|
||
使用方式:
|
||
|
||
```java
|
||
@ApiOperation(value="传递token", notes = "传递token")
|
||
@Open(value = "story.get.token", needToken = true/* 设置true,网关会校验token是否存在 */)
|
||
@RequestMapping("token")
|
||
public StoryResult token(StoryParam story, HttpServletRequest request) {
|
||
OpenContext openContext = ServiceContext.getCurrentContext().getOpenContext();
|
||
StoryResult result = new StoryResult();
|
||
result.setName("appAuthToken:" + openContext.getAppAuthToken());
|
||
return result;
|
||
}
|
||
```
|
||
|
||
指定了needToken=true后,网关会判断客户端是否传了`app_auth_token`参数,没有传则返回错误信息。
|
||
|
||
网关默认简单校验参数值是否存在,如果要校验有效性,需要自己实现。
|
||
|
||
自己实现步骤:
|
||
|
||
- 设置`ApiConfig中的tokenValidator属性`
|
||
|
||
`TokenValidator`是一个函数式接口,可以直接使用Lambda表达式,示例代码如下:
|
||
|
||
```java
|
||
@Component
|
||
public class MyConfig {
|
||
|
||
@PostConstruct
|
||
public void after() {
|
||
ApiConfig.getInstance().setTokenValidator(apiParam -> {
|
||
// 获取客户端传递过来的token
|
||
String token = apiParam.fetchAccessToken();
|
||
return !StringUtils.isBlank(token);
|
||
// TODO: 校验token有效性,可以从redis中读取
|
||
|
||
// 返回true表示这个token真实、有效
|
||
});
|
||
}
|
||
}
|
||
```
|