Files
sa-token/sa-token-doc/sso/message-push.md

7.1 KiB
Raw Permalink Blame History

消息推送机制

消息推送机制简单来讲就是sso-client 端按照特点格式构建一个 http 请求,调用 sso-server 端的 /sso/pushS 接口sso-server 接收到消息后做出处理回应 sso-client 端。

消息推送是相互的sso-server 端也可以构建 http 请求,调用 sso-client 端的 /sso/pushC 接口。

消息推送机制是应用与认证中心相互沟通的桥梁ticket 校验、单点注销等行为都是依赖消息推送机制来实现的。

本篇将介绍在 Sa-Token SSO 模块中sso-server 端和 sso-client 端分别内置了哪些消息模块,以及如何自定义消息处理器。

1、sso-server 端内置消息处理器

1.1、checkTicketticket 校验)

作用:在 SSO 模式三下为 sso-client 提供 ticket 校验能力,返回 loginId 等数据

http://{sso-server主机地址}/sso/pushS

接收参数:

参数 是否必填 说明
msgType 消息类型,此处填 checkTicket
ticket ticket 码
client 客户端标识,可不填,代表是一个匿名应用
ssoLogoutCall Client 端单点注销时 - 回调 URL 参数名称 (匿名 Client 时使用)
timestamp 当前时间戳13位
nonce 随机字符串
sign 签名,生成算法示例:md5( client={client值}&msgType={checkTicket}&nonce={随机字符串}&ticket={ticket码}&timestamp={13位时间戳}&key={secretkey秘钥} )

签名算法规则将所有参数按照字典顺序依次排列key除外挂在最后面然后进行 md5 摘要。以下不再赘述。

返回值示例:

{
  "code": 200,   // 返回 200=成功500=失败
  "msg": "ok",
  "data": "10001",
  "loginId": "10001",   // 此 ticket 对应的认证中心 loginId 
  "tokenValue": "5db12b02-9c8e-4e36-8ed9-bf295caed80e",   // 对应的认证中心会话 token 
  "deviceId": "MxOTCLWi5NXGqFQZBFdsH66Ni5YTJ8q0",   // 对应的认证中心登录设备 id
  "remainTokenTimeout": 2591999,   // token 剩余有效期
  "remainSessionTimeout": 2591999   // Access-Session 会话剩余有效期
}

1.2、signout单点注销

作用:为 sso-client 提供单点注销能力

http://{sso-server主机地址}/sso/pushS

接收参数:

参数 是否必填 说明
msgType 消息类型,此处填 signout
loginId 账号id
client 客户端标识,可不填,代表是一个匿名应用
deviceId 客户端设备 id
timestamp 当前时间戳13位
nonce 随机字符串
sign 签名,生成算法示例:md5( client={client值}&deviceId={设备id}&msgType={signout}&nonce={随机字符串}&loginId={loginId}&timestamp={13位时间戳}&key={secretkey秘钥} )

返回值示例:

{
  "code": 200,   // 返回 200=成功500=失败
  "msg": "ok",
  "data": null
}

2、sso-client 端内置消息处理器

2.1、logoutCall单点注销回调

作用:接收来自 sso-server 的单点注销回调通知

http://{sso-client主机地址}/sso/pushC

接收参数:

参数 是否必填 说明
msgType 消息类型,此处填 logoutCall
loginId 账号id
deviceId 客户端设备 id
timestamp 当前时间戳13位
nonce 随机字符串
sign 签名,生成算法示例:md5( deviceId={设备id}&msgType={logoutCall}&nonce={随机字符串}&loginId={loginId}&timestamp={13位时间戳}&key={secretkey秘钥} )

返回值示例:

{
  "code": 200,   // 返回 200=成功500=失败
  "msg": "单点注销回调成功",
  "data": null
}

3、认证中心自定义消息处理器

当然你也可以通过自定义消息处理器的方式,来扩展消息推送能力,这将非常有助于你完成一些应用与认证中心的自定义数据交互。

假设我们现在有如下需求:在 sso-client 获取 sso-server 端指定账号 id 的昵称、头像等信息,即:用户资料的拉取。

首先,我们需要在 sso-server 实现一个消息处理器:

@RestController
public class SsoServerController {

	// 配置SSO相关参数 
	@Autowired
	private void configSso(SaSsoServerTemplate ssoServerTemplate) {

		// 添加消息处理器userinfo (获取用户资料) (用于为 client 端开放拉取数据的接口)
		ssoServerTemplate.messageHolder.addHandle("userinfo", (ssoTemplate, message) -> {
			System.out.println("收到消息:" + message);

			// 自定义返回结果(模拟)
			return SaResult.ok()
					.set("id", message.get("loginId"))
					.set("name", "LinXiaoYu")
					.set("sex", "女")
					.set("age", 18);
		});

	}

}

4、应用端调用消息推送接口获取数据

首先保证在配置文件里要配置上消息推送的具体地址

# sa-token配置 
sa-token:
    # sso-client 相关配置
    sso-client:
        # 应用标识
        client: sso-client3
        # sso-server 端主机地址
        server-url: http://sa-sso-server.com:9000
        # sso-server 端推送消息地址
		# 配置 server-url 后,框架可自动计算对应的 push-url 地址,也可以单独配置 push-url 地址,两者选其一即可
        # push-url: http://sa-sso-server.com:9000/sso/pushS
        # API 接口调用秘钥
        secret-key: SSO-C3-kQwIOrYvnXmSDkwEiFngrKidMcdrgKor
# sso-client 相关配置
# 应用标识
sa-token.sso-client.client=sso-client3
# sso-server 端主机地址
sa-token.sso-client.server-url=http://sa-sso-server.com:9000
# sso-server 端推送消息地址
# 配置 server-url 后,框架可自动计算对应的 push-url 地址,也可以单独配置 push-url 地址,两者选其一即可
sa-token.sso-client.push-url=http://sa-sso-server.com:9000/sso/pushS
# API 接口调用秘钥
sa-token.sso-client.secret-key=SSO-C3-kQwIOrYvnXmSDkwEiFngrKidMcdrgKor

然后在需要拉取资料的地方:

// 查询我的账号信息sso-client 前端 -> sso-client 后端 -> sso-server 后端
@RequestMapping("/sso/myInfo")
public Object myInfo() {
	// 如果尚未登录
	if( ! StpUtil.isLogin()) {
		return "尚未登录,无法获取";
	}

	// 获取本地 loginId
	Object loginId = StpUtil.getLoginId();

	// 构建消息对象 
	SaSsoMessage message = new SaSsoMessage();
	message.setType("userinfo");
	message.set("loginId", loginId);
	
	// 推送至 sso-server并接收响应数据 
	SaResult result = SaSsoClientUtil.pushMessageAsSaResult(message);

	// 返回给前端
	return result;
}