什么是单点登录及作用

在程序开发中,特别是网站类开发,会接触到单点登录(SSO),什么是单点登录?,单点登录(SSO)有什么用?下面软币网小编来来介绍一下:

一、什么是单点登录?

单点登录的英文名叫做:Single Sign On(简称SSO)。

在初学/以前的时候,一般我们就单系统,所有的功能都在同一个系统上。
单点登录(SSO)
单点登录(SSO)

后来,我们为了合理利用资源和降低耦合性,于是把单系统拆分成多个子系统。

回顾:分布式基础知识

单点登录(SSO)
单点登录(SSO) - 舆管家

拆分成多个子系统

比如阿里系的淘宝和天猫,很明显地我们可以知道这是两个系统,但是你在使用的时候,登录了天猫,淘宝也会自动登录。
单点登录(SSO)
单点登录(SSO)

简单来说,单点登录就是在多个系统中,用户只需一次登录,各个系统即可感知该用户已经登录。

二、回顾单系统登录

在我初学JavaWeb的时候,登录和注册是我做得最多的一个功能了(初学Servlet的时候做过、学SpringMVC的时候做过、跟着做项目的时候做过…),反正我也数不清我做了多少次登录和注册的功能了…这里简单讲述一下我们初学时是怎么做登录功能的。

HTTP是无状态的协议

众所周知,HTTP是无状态的协议,这意味着服务器无法确认用户的信息。于是乎,W3C就提出了:给每一个用户都发一个通行证,无论谁访问的时候都需要携带通行证,这样服务器就可以从通行证上确认用户的信息。通行证就是Cookie。

如果说Cookie是检查用户身上的”通行证“来确认用户的身份,那么Session就是通过检查服务器上的”客户明细表“来确认用户的身份的。Session相当于在服务器中建立了一份“客户明细表”。

HTTP协议是无状态的,Session不能依据HTTP连接来判断是否为同一个用户。于是乎:服务器向用户浏览器发送了一个名为JESSIONID的Cookie,它的值是Session的id值。其实Session是依据Cookie来识别是否是同一个用户。

所以,一般我们单系统实现登录会这样做:

登录:将用户信息保存在Session对象中
- 如果在Session对象中能查到,说明已经登录
如果在Session对象中查不到,说明没登录(或者已经退出了登录)
注销(退出登录):从Session中删除用户的信息
记住我(关闭掉浏览器后,重新打开浏览器还能保持登录状态):配合Cookie来用

我之前Demo的代码,可以参考一下:

/**
 * 用户登陆
 */
@PostMapping(value = "/user/session", produces = {"application/json;charset=UTF-8"})
public Result login(String mobileNo, String password, String inputCaptcha, HttpSession session, HttpServletResponse response) {
 //判断验证码是否正确
 if (WebUtils.validateCaptcha(inputCaptcha, "captcha", session)) {
 //判断有没有该用户
 User user = userService.userLogin(mobileNo, password);
 if (user != null) {
 /*设置自动登陆,一个星期. 将token保存在数据库中*/
 String loginToken = WebUtils.md5(new Date().toString() + session.getId());
 user.setLoginToken(loginToken);
 User user1 = userService.userUpload(user);
 session.setAttribute("user", user1);
 CookieUtil.addCookie(response,"loginToken",loginToken,604800);
 return ResultUtil.success(user1);
 } else {
 return ResultUtil.error(ResultEnum.LOGIN_ERROR);
 }
 } else {
 return ResultUtil.error(ResultEnum.CAPTCHA_ERROR);
 }
}
/**
 * 用户退出
 */
@DeleteMapping(value = "/session", produces = {"application/json;charset=UTF-8"})
public Result logout(HttpSession session,HttpServletRequest request,HttpServletResponse response ) {
 //删除session和cookie
 session.removeAttribute("user");
 CookieUtil.clearCookie(request, response, "loginToken");
 return ResultUtil.success();
}
/**
* @author ozc
* @version 1.0
* <p>
* 拦截器;实现自动登陆功能
*/
public class UserInterceptor implements HandlerInterceptor {
@Autowired
private UserService userService;
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object o) throws Exception {
 User sessionUser = (User) request.getSession().getAttribute("user");
 // 已经登陆了,放行
 if (sessionUser != null) {
 return true;
 } else {
 //得到带过来cookie是否存在
 String loginToken = CookieUtil.findCookieByName(request, "loginToken");
 if (StringUtils.isNotBlank(loginToken)) {
 //到数据库查询有没有该Cookie
 User user = userService.findUserByLoginToken(loginToken);
 if (user != null) {
 request.getSession().setAttribute("user", user);
 return true;
 } else {
 //没有该Cookie与之对应的用户(Cookie不匹配)
 CookieUtil.clearCookie(request, response, "loginToken");
 return false;
 }
 } else {
 //没有cookie、也没有登陆。是index请求获取用户信息,可以放行
 if (request.getRequestURI().contains("session")) {
 return true;
 }
 //没有cookie凭证
 response.sendRedirect("/login.html");
 return false;
 }
 }
}
}

总结一下上面代码的思路:

用户登录时,验证用户的账户和密码
生成一个Token保存在数据库中,将Token写到Cookie中
将用户数据保存在Session中
请求时都会带上Cookie,检查有没有登录,如果已经登录则放行

Cookie的作用是什么?和Session有什么区别?

Cookie 和 Session都是用来跟踪浏览器用户身份的会话方式,但是两者的应用场景不太一样。

Cookie 一般用来保存用户信息 比如①我们在 Cookie 中保存已经登录过得用户信息,下次访问网站的时候页面可以自动帮你登录的一些基本信息给填了;②一般的网站都会有保持登录也就是说下次你再访问网站的时候就不需要重新登录了,这是因为用户登录的时候我们可以存放了一个 Token 在 Cookie 中,下次登录的时候只需要根据 Token 值来查找用户即可(为了安全考虑,重新登录一般要将 Token 重写);③登录一次网站后访问网站其他页面不需要重新登录。Session 的主要作用就是通过服务端记录用户的状态。典型的场景是购物车,当你要添加商品到购物车的时候,系统不知道是哪个用户操作的,因为 HTTP 协议是无状态的。服务端给特定的用户创建特定的 Session 之后就可以标识这个用户并且跟踪这个用户了。

Cookie 数据保存在客户端(浏览器端),Session 数据保存在服务器端。

Cookie 存储在客户端中,而Session存储在服务器上,相对来说 Session 安全性更高。如果使用 Cookie 的一些敏感信息不要写入 Cookie 中,最好能将 Cookie 信息加密然后使用到的时候再去服务器端解密。

三、多系统登录的问题与解决

3.1 Session不共享问题

单系统登录功能主要是用Session保存用户信息来实现的,但我们清楚的是:多系统即可能有多个Tomcat,而Session是依赖当前系统的Tomcat,所以系统A的Session和系统B的Session是不共享的。
A的Session和系统B的Session是不共享的
A的Session和系统B的Session是 不共享的 舆情宝

解决系统之间Session不共享问题有一下几种方案:

Tomcat集群Session全局复制(集群内每个tomcat的session完全同步)【会影响集群的性能呢,不建议】
根据请求的IP进行Hash映射到对应的机器上(这就相当于请求的IP一直会访问同一个服务器)【如果服务器宕机了,会丢失了一大部分Session的数据,不建议】
把Session数据放在Redis中(使用Redis模拟Session)【建议】

我们可以将登录功能单独抽取出来,做成一个子系统。
什么是单点登录(SSO)?单点登录(SSO)到底什么意思?

抽取出来成为子系统

SSO(登录系统)的逻辑如下:

// 登录功能(SSO单独的服务)
@Override
public TaotaoResult login(String username, String password) throws Exception {
 //根据用户名查询用户信息
 TbUserExample example = new TbUserExample();
 Criteria criteria = example.createCriteria();
 criteria.andUsernameEqualTo(username);
 List<TbUser> list = userMapper.selectByExample(example);
 if (null == list || list.isEmpty()) {
 return TaotaoResult.build(400, "用户不存在");
 }
 //核对密码
 TbUser user = list.get(0);
 if (!DigestUtils.md5DigestAsHex(password.getBytes()).equals(user.getPassword())) {
 return TaotaoResult.build(400, "密码错误");
 }
 //登录成功,把用户信息写入redis
 //生成一个用户token
 String token = UUID.randomUUID().toString();
 jedisCluster.set(USER_TOKEN_KEY + ":" + token, JsonUtils.objectToJson(user));
 //设置session过期时间
 jedisCluster.expire(USER_TOKEN_KEY + ":" + token, SESSION_EXPIRE_TIME);
 return TaotaoResult.ok(token);
}

其他子系统登录时,请求SSO(登录系统)进行登录,将返回的token写到Cookie中,下次访问时则把Cookie带上:

public TaotaoResult login(String username, String password, 
 HttpServletRequest request, HttpServletResponse response) {
 //请求参数
 Map<String, String> param = new HashMap<>();
 param.put("username", username);
 param.put("password", password);
 //登录处理
 String stringResult = HttpClientUtil.doPost(REGISTER_USER_URL + USER_LOGIN_URL, param);
 TaotaoResult result = TaotaoResult.format(stringResult);
 //登录出错
 if (result.getStatus() != 200) {
 return result;
 }
 //登录成功后把取token信息,并写入cookie
 String token = (String) result.getData();
 //写入cookie
 CookieUtils.setCookie(request, response, "TT_TOKEN", token);
 //返回成功
 return result;
}

总结:

SSO系统生成一个token,并将用户信息存到Redis中,并设置过期时间
其他系统请求SSO系统进行登录,得到SSO返回的token,写到Cookie中
每次请求时,Cookie都会带上,拦截器得到token,判断是否已经登录

到这里,其实我们会发现其实就两个变化:

将登陆功能抽取为一个系统(SSO),其他系统请求SSO进行登录
本来将用户信息存到Session,现在将用户信息存到Redis

3.2 Cookie跨域的问题

上面我们解决了Session不能共享的问题,但其实还有另一个问题。Cookie是不能跨域的

比如说,我们请求http://www.ibixue.com/时,浏览器会自动把ibixue.com的Cookie带过去给google的服务器,而不会把http://www.gookang.com的Cookie带过去给google的服务器。

这就意味着,由于域名不同,用户向系统A登录后,系统A返回给浏览器的Cookie,用户再请求系统B的时候不会将系统A的Cookie带过去。

针对Cookie存在跨域问题,有几种解决方案:

服务端将Cookie写到客户端后,客户端对Cookie进行解析,将Token解析出来,此后请求都把这个Token带上就行了
多个域名共享Cookie,在写到客户端的时候设置Cookie的domain。
将Token保存在SessionStroage中(不依赖Cookie就没有跨域的问题了)

到这里,我们已经可以实现单点登录了。

3.3 CAS原理

说到单点登录,就肯定会见到这个名词:CAS (Central Authentication Service),下面说说CAS是怎么搞的。

如果已经将登录单独抽取成系统出来,我们还能这样玩。现在我们有两个系统,分别是www.ibixue.com和www.gookang.com,一个 www.ruanally.com

首先,用户想要访问系统A www.ibixue.com受限的资源(比如说购物车功能,购物车功能需要登录后才能访问),系统A www.ibixue.com发现用户并没有登录,于是重定向到sso认证中心,并将自己的地址作为参数。请求的地址如下:

www.ruanally.com?service=www.ibixue.com

sso认证中心发现用户未登录,将用户引导至登录页面,用户进行输入用户名和密码进行登录,用户与认证中心建立全局会话(生成一份Token,写到Cookie中,保存在浏览器上)
什么是单点登录(SSO)?单点登录(SSO)到底什么意思?【附逻辑Demo实例】
什么是单点登录(SSO)?单点登录(SSO)到底什么意思?【附逻辑Demo实例】

随后,认证中心重定向回系统A,并把Token携带过去给系统A,重定向的地址如下:

www.ibixue.com?token=xxxxxxx

接着,系统A去sso认证中心验证这个Token是否正确,如果正确,则系统A和用户建立局部会话(创建Session)。到此,系统A和用户已经是登录状态了。
什么是单点登录(SSO)?单点登录(SSO)到底什么意思?【附逻辑Demo实例】
什么是单点登录(SSO)?单点登录(SSO)到底什么意思?【附逻辑Demo实例】

此时,用户想要访问系统B www.gookang.com受限的资源(比如说订单功能,订单功能需要登录后才能访问),系统B www.gookang.com发现用户并没有登录,于是重定向到sso认证中心,并将自己的地址作为参数。请求的地址如下:

www.ruanally.com?service=www.gookang.com

注意,因为之前用户与认证中心www.ruanally.com已经建立了全局会话(当时已经把Cookie保存到浏览器上了),所以这次系统B重定向到认证中心www.ruanally.com是可以带上Cookie的。

认证中心根据带过来的Cookie发现已经与用户建立了全局会话了,认证中心重定向回系统B,并把Token携带过去给系统B,重定向的地址如下:

www.gookang.com?token=xxxxxxx

接着,系统B去sso认证中心验证这个Token是否正确,如果正确,则系统B和用户建立局部会话(创建Session)。到此,系统B和用户已经是登录状态了。
标题

看到这里,其实SSO认证中心就类似一个中转站。

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: ecology9.0系统接口中的单点登录功能是指用户只需要通过一次登录验证,就可以在不同的应用程序中无缝地切换而无需再次登录的一种系统集成方式。 单点登录的主要目的是提高用户的使用体验和工作效率。在传统的系统中,用户在使用不同的应用程序时需要反复输入登录凭据,频繁进行登录验证,增加了用户的操作复杂性和时间成本。而通过单点登录功能,用户只需要一次登录即可访问所有相关应用程序,无需重复输入用户名和密码,减少了用户的登录操作次数,提升了工作效率。 实现单点登录的关键在于建立一个中央认证授权系统,该系统负责用户的登录验证和授权管理。当用户登录系统时,中央认证授权系统会对用户进行验证,并生成一个全局唯一的身份凭据,作为用户在不同应用程序间切换时的唯一身份标识。当用户访问其他应用程序时,该应用程序就会通过向中央认证授权系统发送验证请求来确认用户的身份并授权访问。 使用ecology9.0系统接口的单点登录功能,可以实现不同系统、不同平台间的无缝切换和数据共享。例如,一个企业内部的办公系统、人力资源系统和财务系统可以通过单点登录功能实现统一的用户身份验证和权限管理,用户只需要一次登录就可以访问这些系统,方便了企业内部员工的工作流程。 总之,ecology9.0系统接口中的单点登录功能为用户提供了方便快捷的身份验证和切换方式,提高了工作效率和用户体验,并且通过集成不同应用程序实现了数据共享和统一管理。 ### 回答2: Ecology9.0系统接口中的单点登录是一种身份验证方法,它允许用户只需一次登录,就可以访问多个不同的系统或应用,而无需重复输入用户名和密码。 单点登录的核心原理是通过在用户登录时颁发一个令牌(Token)来表示用户的身份,在用户访问其他系统或应用时,只需提供该令牌,就能够在后台进行身份验证,从而实现无缝访问其他系统目的。 在Ecology9.0系统中,单点登录的接口提供了一些必要的功能,以确保用户能够方便地使用单点登录功能。首先,系统接口需要支持用户登录时生成令牌,并在其他系统请求身份验证时验证令牌的有效性。其次,接口需要支持跨系统共享用户信息,以便其他系统能够获取到用户的相关信息。 另外,Ecology9.0系统接口中的单点登录还需要提供一些安全措施,以保护用户的登录信息和隐私。例如,接口可能会采用加密技术来保护令牌的传输过程,防止令牌被截获并被他人误用。此外,接口还可能提供一些权限管理功能,以确保只有经过授权的系统才能够访问用户的信息。 总的来说,Ecology9.0系统接口中的单点登录是一种方便且安全的身份验证方法,它可以提高用户在多个系统或应用中的访问效率,同时保护用户的登录信息和隐私。通过单点登录,用户可以在Ecology9.0系统中一次登录,就能够顺利访问其他系统,提高工作效率。 ### 回答3: Ecology 9.0系统接口中的单点登录功能是指用户只需要一次登录就可以访问多个与该系统相关的应用程序或网站。这种功能主要基于统一身份认证原理,将用户的登录凭证(如用户名和密码)保存在一个中央身份管理系统中。 当用户首次登录一个系统或网站时,系统会验证其身份,并生成一个唯一的令牌,该令牌用于认证和授权用户的访问权限。然后,系统会将该令牌传递给其他与该系统关联的应用程序或网站。当用户访问其他应用程序或网站时,系统会自动使用令牌进行身份验证,而不需要用户再次输入用户名和密码。 单点登录功能有以下几个优势: 1. 减少用户登录次数:用户只需要一次登录就可以访问多个应用程序或网站,避免了频繁的登录操作,提高了用户的使用便利性和效率。 2. 提升用户体验:用户无需记住多个不同的用户名和密码,只需要记住一个即可,大大简化了用户的登录流程,提升了用户的使用体验。 3. 增强安全性:单点登录功能可以提供更高的安全性保障。因为用户的登录凭证只需要传递一次,可以减少信息泄露的风险。此外,通过统一的身份管理系统可以对用户进行集中管理和监控,便于及时发现和解决潜在的安全问题。 总之,Ecology 9.0系统接口中的单点登录功能可以提升用户的便利性和使用体验,同时增强系统的安全性。这是一项非常有价值和有意义的功能,在企业信息化建设中具有重要的作用

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值