我们知道单点登录系统:出名的有apereo的cas和OAuth2、JWT等。通常认证有两个方案:
一个方案是基于token,另一个方案是基于cookie的。基于xxl-sso,我们可以学习到实现的基本是基于过滤器的增强,从而实现重定向。我之前的公司使用的是基于apereo的cas进行的二次开发配合统一授权系统使用。cas的单点登录的登录涉及到三个概念:
TGC(ticket-granting cookie)
Service Ticket ( ST )
Ticket Granted Cookie ( TGC )
同时采用webflow实现流转。其相对来说,比较复杂。其本质还是基于过滤器。
由此我们可以看到xxl-sso的思想也是基于过滤器实现自己的增强。
我们可以回忆CAS的登录场景:
首先登录业务系统,或者登录一个父系统,从而进入到子系统。这个过程通常需要经历三个url的跳转:
业务系统的url
如果没有登录进行重定向跳转到认证中心
认证中心登录后,再跳回到业务系统的url
1).进行业务系统登录,如果没有登录,则跳转到认证中心
2).进入到认证,通常单点登录系统需要配合统一授权系统使用,
也即做菜单权限的分配,将菜单的权限具体分配给到人。
3).持久化用户信息到数据库,进行菜单分配,进行权限控制,
通过APP进行用户信息采集。
4).经过单点登录认证。拿到用户信息,去认证中心认证。
1).首先采集用户信息,持久化到数据库
2).通过账号和密码访问服务端的登录接口就可以拿到token
3).业务系统在拿到token后,可以基于token来进行访问自己想要访问的接口
4).此时可以将token信息放入到redis中,从而实现对token信息的存储。
5).同时可以对token进行续期
可以看到在sso-server启动后,业务系统登录的时候,进行重定向到sso-server,携带sso sessionid进行访问。或者基于token的方案,进行操作。从架构图中可以看到这个重定向很重要。
启动sso-server端
通过账号和密码访问服务端的登录接口就可以拿到token:
http://localhost:8080/xxl-sso-server/app/login?username=user&password=123456
{"code":200,"msg":null,"data":"1000_62003f860f954cf0a20d6824a01d1f9a"}
拿到token进行访问接口
http://127.0.01:8082/xxl-sso-token-sample-springboot/
可以对ip端口做域名映射,访问业务系统接口:
{
"code": 200,
"msg": null,
"data": {
"userid": "1001",
"username": "user1",
"plugininfo": null,
"version": "dcb4e801240545328d2c1ac691bf0f9c",
"expireMinute": 1440,
"expireFreshTime": 1674649196500
}
}
进行退出操作:
http://127.0.01:8082/xxl-sso-token-sample-springboot/logout
再次请求业务系统的接口:
http://127.0.01:8082/xxl-sso-token-sample-springboot
可以看到已经显示无效了。
首先需要做一个域名映射:
127.0.0.1 xxlssoserver.com
首先进行访问:
http://localhost:8081/xxl-sso-web-sample-springboot
进行拦截器会进行登录拦截
进行重定向:
http://xxlssoserver.com:8080/xxl-sso-server/login?redirect_url=http://localhost:8081/xxl-sso-web-sample-springboot/
进入认证中心,进行认证:
http://127.0.0.1:8081/xxl-sso-web-sample-springboot/?xxl_sso_sessionid=1000_06a1984b96a244a5927cdae2596e79bb
登录后,会跳转到成功页面:
http://localhost:8081/xxl-sso-web-sample-springboot/?xxl_sso_sessionid=1000_4be8c6cdaaa149b394636921d0d07a7d
【user】login success.
点击Logout 然后进行logout:
http://xxlssoserver.com:8080/xxl-sso-server/logout
然后就可以退出登录了。
从而跳转到登录页面:
http://localhost:8080/xxl-sso-server/login
以上就是两套方案请求的过程。
可以看到徐雪里老师还是很厉害的!