# 接入安全验证 - Token
为了保障安全,框架支持给接入的 WebSocket 连接验证 Token,如果不设置 Token 同时又将框架的端口暴露在公网将会非常危险。
炸毛框架兼容 OneBot 标准的机器人客户端,所以自带一个 Token 验证器。
关于 Access Token 方面的标准规范,请参考下面内容:
以 go-cqhttp 举例,如果要设置验证,则将 go-cqhttp 配置文件中的
access_token
项填入内容即可。
# 验证位置
框架对 Token 的验证是内置的,在事件 open
(WebSocket 连接接入时)触发。
如果是兼容 OneBot 标准的客户端接入,则一切都是兼容的。
如果是自定义的其他 WebSocket 客户端也想接入框架,那么其他 WebSocket 客户端也需要进行相应的设置才能利用此 Token 验证。
如果验证成功(Token 符合要求)则分发事件 @OnOpenEvent
,否则此事件不触发,同时断开 WebSocket 连接。
# 标准验证(字符串形式)
默认的情况下,在框架的全局配置文件 global.php
中,对配置项 access_token
填入与 OneBot 客户端相同的 access_token
即可实现鉴权。下面是一个最基本的和 go-cqhttp 设置鉴权配置:
go-cqhttp 的配置段:
// 访问密钥, 强烈推荐在公网的服务器设置
access_token: "emhhbWFvLXJvYm90"
2
框架的配置文件配置段:
/** onebot连接约定的token */
$config["access_token"] = 'emhhbWFvLXJvYm90';
2
然后重启框架和 go-cqhttp 即可。(其他 OneBot 客户端同理)
# 自定义验证(Token 验证)
有些情况下,使用一个单一的字符串可能无法满足你对 Token 验证的安全需求,需要自定义一些判断模式才能满足,所以框架的 access_token
配置项支持动态的闭包函数自行编写判断逻辑,例如下面的一个例子,我可以让框架同时允许接入多个不同 token 的 WebSocket 连接:
/** onebot连接约定的token */
$config["access_token"] = function($token){
$allow = ['emhhbWFvLXJvYm90','aXMtdmVyeS1nb29k'];
if (in_array($token, $allow)) return true;
else return false;
};
2
3
4
5
6
# 自定义验证(open 事件)
当然,这里设置了自定义方式,其实你也可以在下一层的 @OnOpenEvent
注解事件中进行自定义内容和判断,具体见 @OnOpenEvent
的相关章节。