XXL-SSO 是一个分布式单点登陆框架。只须要登陆一次就能够访问全部相互信任的应用系统。
拥有"轻量级、分布式、跨域、Cookie+Token均支持、Web+APP均支持"等特性;。现已开放源代码,开箱即用。html
源码仓库地址 | Release Download |
---|---|
https://github.com/xuxueli/xxl-sso | Download |
https://gitee.com/xuxueli0323/xxl-sso | Download |
基于Cookie,相关概念可参考 "章节 4.6";git
- xxl-sso-server:中央认证服务,支持集群; - xxl-sso-core:Client端依赖; - xxl-sso-samples:单点登录Client端接入示例项目; - xxl-sso-web-sample-springboot:基于Cookie接入方式,供用户浏览器访问,springboot版本 - xxl-sso-token-sample-springboot:基于Token接入方式,经常使用于没法使用Cookie的场景使用,如APP、Cookie被禁用等,springboot版本
项目名:xxl-sso-server
配置文件位置:application.propertiesgithub
…… // redis 地址: 如 "{ip}"、"{ip}:{port}"、"{redis/rediss}://xxl-sso:{password}@{ip}:{port:6379}/{db}";多地址逗号分隔 xxl.sso.redis.address=redis://127.0.0.1:6379 // 登陆态有效期窗口,默认24H,当登陆态有效期窗口过半时,自动顺延一个周期; xxl.sso.redis.expire.minite=1440
项目名:xxl-sso-web-sample-springboot
<dependency> <groupId>com.xuxueli</groupId> <artifactId>xxl-sso-core</artifactId> <version>${最新稳定版}</version> </dependency>
参考代码:com.xxl.sso.sample.config.XxlSsoConfigweb
@Bean public FilterRegistrationBean xxlSsoFilterRegistration() { // xxl-sso, redis init JedisUtil.init(xxlSsoRedisAddress); // xxl-sso, filter init FilterRegistrationBean registration = new FilterRegistrationBean(); registration.setName("XxlSsoWebFilter"); registration.setOrder(1); registration.addUrlPatterns("/*"); registration.setFilter(new XxlSsoWebFilter()); registration.addInitParameter(Conf.SSO_SERVER, xxlSsoServer); registration.addInitParameter(Conf.SSO_LOGOUT_PATH, xxlSsoLogoutPath); return registration; }
配置文件位置:application.propertiesredis
…… ### xxl-sso (CLient端SSO配置) ##### SSO Server认证中心地址(推荐以域名方式配置认证中心,本机可参考章节"2.5"修改host文件配置域名指向) xxl.sso.server=http://xxlssoserver.com:8080/xxl-sso-server ##### 注销登录path,值为Client端应用的相对路径 xxl.sso.logout.path=/logout ##### 路径排除Path,容许设置多个,且支持Ant表达式。用于排除SSO客户端不须要过滤的路径 xxl-sso.excluded.paths= ### redis // redis address, like "{ip}"、"{ip}:{port}"、"{redis/rediss}://xxl-sso:{password}@{ip}:{port:6379}/{db}";Multiple "," separated xxl.sso.redis.address=redis://xxl-sso:password@127.0.0.1:6379/0
环境准备:启动Redis、初始化Mysql表数据;spring
### 在host文件中添加如下内容0 127.0.0.1 xxlssoserver.com 127.0.0.1 xxlssoclient1.com 127.0.0.1 xxlssoclient2.com
分别运行 "xxl-sso-server" 与 "xxl-sso-web-sample-springboot"sql
一、SSO认证中心地址:
http://xxlssoserver.com:8080/xxl-sso-server数据库
二、Client01应用地址:
http://xxlssoclient1.com:8081/xxl-sso-web-sample-springboot/跨域
三、Client02应用地址:
http://xxlssoclient2.com:8081/xxl-sso-web-sample-springboot/浏览器
SSO登陆/注销流程验证
正常状况下,登陆流程以下:
一、访问 "Client01应用地址" ,将会自动 redirect 到 "SSO认证中心地址" 登陆界面;
二、成功登陆后,将会自动 redirect 返回到 "Client01应用地址",并切换为已登陆状态;
三、此时,访问 "Client02应用地址",不需登录将会自动切换为已登陆状态;
正常状况下,注销流程以下:
一、访问 "Client01应用地址" 配置的 "注销登录path",将会自动 redirect 到 "SSO认证中心地址" 并自动注销登录状态;
二、此时,访问 "Client02应用地址",也将会自动注销登录状态;
基于Token,相关概念可参考 "章节 4.7";(在一些没法使用Cookie的场景下,可以使用该方式,不然能够忽略本章节)
可参考 "章节二" 搭建;
"认证中心" 搭建成功后,默认为Token方式登录提供API接口以下:
项目名:xxl-sso-token-sample-springboot
可参考 "章节 2.4" 部署 "单点登录Client端接入示例项目",惟一不一样点是:将web应用的 "XxlSsoFilter" 更换为app应用 "XxlSsoTokenFilter";
环境准备:启动Redis、初始化Mysql表数据;
### 在host文件中添加如下内容0 127.0.0.1 xxlssoserver.com 127.0.0.1 xxlssoclient1.com 127.0.0.1 xxlssoclient2.com
分别运行 "xxl-sso-server" 与 "xxl-sso-token-sample-springboot"
一、SSO认证中心地址:
http://xxlssoserver.com:8080/xxl-sso-server
二、Client01应用地址:
http://xxlssoclient1.com:8082/xxl-sso-token-sample-springboot/
三、Client02应用地址:
http://xxlssoclient2.com:8082/xxl-sso-token-sample-springboot/
SSO登陆/注销流程验证
可参考测试用例 :com.xxl.app.sample.test.TokenClientTest
正常状况下,登陆流程以下:
一、获取用户输入的帐号密码后,请求SSO Server的登陆接口,获取用户 sso sessionid ;(参考代码:TokenClientTest.loginTest)
二、登录成功后,获取到 sso sessionid ,须要主动存储,后续请求时须要设置在 Header参数 中;
三、此时,使用 sso sessionid 访问受保护的 "Client01应用" 和 "Client02应用" 提供的接口,接口均正常返回;(参考代码:TokenClientTest.clientApiRequestTest)
正常状况下,注销流程以下:
一、请求SSO Server的注销接口,注销登录凭证 sso sessionid ;(参考代码:TokenClientTest.logoutTest)
二、注销成功后,sso sessionid 将会全局失效;
三、此时,使用 sso sessionid 访问受保护的 "Client01应用" 和 "Client02应用" 提供的接口,接口请求将会被拦截,提示未登陆并返回状态码 501 ;(参考代码:TokenClientTest.clientApiRequestTest)
XXL-SSO 是一个分布式单点登陆框架。只须要登陆一次就能够访问全部相互信任的应用系统。
借助 XXL-SSO,能够快速实现分布式系统单点登陆。
概念 | 说明 |
---|---|
SSO Server | 中央认证服务,支持集群; |
SSO Client | 接入SSO认证中心的Client应用; |
SSO SessionId | 登陆用户会话ID,SSO 登陆成功为用户自动分配; |
SSO User | 登陆用户信息,与 SSO SessionId 相对应; |
基于Cookie,未登陆状态请求:
基于Token,未登陆状态请求:
支持自定义登陆态有效期窗口,默认24H,当登陆态有效期窗口过半时,自动顺延一个周期;
未记住密码时,关闭浏览器则登陆态失效;记住密码时,登陆态自动延期,在自定义延期时间的基础上,原则上能够无限延期;
自定义路径排除Path,容许设置多个,且支持Ant表达式。用于排除SSO客户端不须要过滤的路径
欢迎参与项目贡献!好比提交PR修复一个bug,或者新建 Issue 讨论新特性或者变动。
更多接入的公司,欢迎在 登记地址 登记,登记仅仅为了产品推广。
产品开源免费,而且将持续提供免费的社区技术支持。我的或企业内部可自由的接入和使用。
不管金额多少都足够表达您这份心意,很是感谢 :) 前往捐赠