1、什么是单点登录?
在多个系统中,用户只需登录一次,各个系统即可感知该用户已经登录。
2、JWT原理
JSON Web Tokens的格式组成,jwt是一段被base64编码过的字符序列,用点号分隔,一共由三部分组成,头部header,消息体playload和签名sign。
-
jwt的头部Header是json格式:
{
“typ”:“JWT”,
“alg”:“HS256”,
“exp”:1491066992916
}其中typ是type的简写,代表该类型是JWT类型,加密方式声明是HS256,exp代表当前时间.
-
jwt的消息体Playload
{
“userid”:“123456”,
“iss”:“companyName”
}消息体的具体字段可根据业务需要自行定义和添加,只需在解密的时候注意拿字段的key值获取value。
-
签名sign的生成
最后是签名,签名的生成是把header和playload分别使用base64url编码,接着用’.‘把两个编码后的字符串连接起来,再把这拼接起来的字符串配合密钥进行HMAC SHA-256算法加密,最后再次base64编码下,这就拿到了签名sign. 最后把header和playload和sign用’.‘ 连接起来就生成了整个JWT。