shiro - 使用 token

整合文章:

在这里插入图片描述

文章目录

一、session的状态保持及弊端

当用户第一次通过浏览器使用用户名和密码访问服务器时,

  • 服务器会验证用户数据,
  • 验证成功后在服务器端写入session数据,
  • 向客户端浏览器返回sessionid,浏览器将sessionid保存在cookie中,
  • 当用户再次访问服务器时,会携带sessionid,
  • 服务器会拿着sessionid从 数据库 内存(缓存) 获取session数据,然后进行用户信息查询,
  • 查询到,就会将查询到的用户信息返回,从而实现状态保持。
    在这里插入图片描述

弊端:

  1. 服务器压力增大
    通常session是存储在内存中的,每个用户通过认证之后都会将session数据保存在服务器的内存中,而当用户量增大时,服务器的压力增大。

  2. CSRF跨站伪造请求攻击
    session是基于cookie进行用户识别的, cookie如果被截获(虽然同源机制,cookie不容易被获取 ),用户就会很容易受到跨站请求伪造的攻击。

  3. 扩展性不强(这个是重点)
    如果将来搭建了多个服务器,虽然每个服务器都执行的是同样的业务逻辑,但是session数据是保存在内存中的(不是共享的),用户第一次访问的是服务器1,当用户再次请求时可能访问的是另外一台服务器2,服务器2获取不到session信息,就判定用户没有登陆过。

二、token认证机制

token与session的不同主要在

  1. 认证成功后,会对当前用户数据进行加密,生成一个加密字符串token,返还给客户端(服务器端并不进行保存)

  2. 浏览器会将接收到的token值存储在Local Storage中,
    (通过js代码写入Local Storage,通过js获取,并不会像cookie一样自动携带)

  3. 再次访问时服务器端对token值的处理:

    1. 服务器对浏览器传来的token值进行解密,
    2. 解密完成后进行用户数据的查询,如果查询成功,则通过认证,实现状态保持,

所以,即时有了多台服务器,服务器也只是做了token的解密和用户数据的查询,它不需要在服务端去保留用户的认证信息或者会话信息,

这就意味着基于token认证机制的应用不需要去考虑用户在哪一台服务器登录了,这就为应用的扩展提供了便利,解决了session扩展性的弊端。

在这里插入图片描述

Apache Shiro 用户信息保存在 Session 方案

shiro会自动将用户信息存储在shiro的 Session 中,如下图,取出Session中信息则可以通过User user = (User) SecurityUtils.getSubject().getPrincipal()获取!
在这里插入图片描述

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Security、Shiro和Sa-Token都是用于身份验证和访问控制的安全框架,但它们有不同的特点和核心架构。 1. Spring Security: - 核心架构:Spring Security是基于过滤器链(Filter Chain)的安全框架,通过一系列的过滤器来对请求进行安全验证和访问控制。 - 特点:Spring Security提供了全面的安全解决方案,包括身份验证、授权、记住我等功能。它与Spring框架无缝集成,并且具有灵活性和可扩展性。 - 使用示例:在Spring Boot项目,您可以通过添加Spring Security的依赖并配置相关的安全规则来实现身份验证和授权功能。 2. Shiro: - 核心架构:Shiro是一个轻量级的Java安全框架,使用一组过滤器和拦截器来处理身份验证和授权。 - 特点:Shiro提供了简单易用的API,可以轻松地实现身份验证、授权、加密等功能。它具有灵活性和可扩展性,并且可以与任何Java应用程序集成。 - 使用示例:在Java应用程序,您可以使用Shiro的API来实现身份验证和授权。配置Shiro的INI文件或编程方式来定义安全规则。 3. Sa-Token: - 核心架构:Sa-Token是一个基于Token的轻量级Java安全框架,使用Token进行身份验证和授权。 - 特点:Sa-Token具有简单易用、高性能和低侵入性的特点。它使用Token来管理用户身份,支持多种Token生成和存储方式,并提供了丰富的权限控制功能。 - 使用示例:在Java应用程序,您可以使用Sa-Token的API来生成和验证Token,并通过注解或编程方式定义访问控制规则。 总结来说,Spring Security是一个全面的安全框架,Shiro是一个灵活易用的安全框架,而Sa-Token是一个基于Token的轻量级安全框架。您可以根据项目需求和个人偏好选择适合的框架进行使用。具体的使用方法和示例可以参考它们的官方文档或相关教程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值