当前位置: 首页 > news >正文

Shiro和SpringSecurity的区别

文章目录

  • 前言
  • 1.Shiro:
    • Shiro的特点:
  • 2.SpringSecurity:
    • SpringSecurity特点:
  • 3.对比:
  • 总结


前言

Shiro 和 Spring Security 都是用于在Java应用程序中实现身份验证(Authentication)和授权(Authorization)功能的安全框架。它们的目标是保护应用程序免受恶意用户的攻击,并提供一系列工具来管理用户、角色和权限。


1.Shiro:

Apache Shiro是一个强大且易用的Java安全框架,能够非常清晰的处理认证、授权、管理会话以及密码加密。使用Shiro的易于理解的API,您可以快速、轻松地获得任何应用程序,从最小的移动应用程序到最大的网络和企业应用程序。

Shiro的特点:

  1. 易于理解的 Java Security API;
  2. 简单的身份认证(登录),支持多种数据源(LDAP,JDBC,Kerberos,ActiveDirectory 等);
  3. 对角色的简单的签权(访问控制),支持细粒度的签权;
  4. 支持一级缓存,以提升应用程序的性能;
  5. 内置的基于 POJO 企业会话管理,适用于 Web 以及非 Web 的环境;
  6. 异构客户端会话访问;
  7. 非常简单的加密 API;
  8. 不跟任何的框架或者容器捆绑,可以独立运行。

2.SpringSecurity:

Spring Security在架构上将认证与授权分离,并提供了扩展点。它是一个轻量级的安全框架,它确保基于Spring的应用程序提供身份验证和授权支持。它与Spring有很好地集成 ,并配备了BCrypt安全算法实现捆绑在一起。

SpringSecurity特点:

  • Sshiro能实现的,Spring Security 基本都能实现;
  • 依赖于Spring体系;
  • 背景强大,因为是Spring全家桶的一员;
  • 集成上更加契合,在使用上,比shiro略负责。

3.对比:

  • Shiro比Spring Security更容易使用,也就是实现上简单一些,同时基本的授权认证Shiro也基本够用;
  • Spring Security社区支持度更高,Spring社区的亲儿子,支持力度和更新维护上有优势,同时和Spring这一套的结合较好。
  • Shiro 功能强大、且 简单、灵活。是Apache 下的项目比较可靠,且不跟任何的框架或者容器绑定,可以独立运行。
  • Shiro支持MD5和SHA系列的加密方式,而SpringSecurity支持的是Bcrypt这种更安全的加密方式。

总结

Shiro更灵活、简单、独立,可以与各种Java应用程序集成。
SpringSecurity更契合 Spring 模块(如 Spring Boot、Spring MVC)。

http://www.lryc.cn/news/153016.html

相关文章:

  • 【STM32】学习笔记(OLED)
  • 概念解析 | 认知雷达:有大脑的雷达
  • B. Long Long
  • CTFhub-文件上传-.htaccess
  • Python中的绝对和相对导入
  • C语言关于与运算符
  • 计算机网络(速率、宽带、吞吐量、时延、发送时延)
  • kubectl入门
  • Android JNI系列详解之ndk-build工具的使用
  • 【业务功能篇90】微服务-springcloud-检索服务-ElasticSearch实战运用-DSL语句
  • QTday4
  • 设计模式之命令模式(Command)的C++实现
  • 取证工具prodiscover的基本操作
  • flutter plugins插件【二】【FlutterAssetsGenerator】
  • 看懂UML类图
  • keras深度学习框架通过简单神经网络实现手写数字识别
  • React 中的 ref 如何操作 dom节点,使输入框获取焦点
  • 最短路Dijkstra,spfa,图论二分图算法AYIT---ACM训练(模板版)
  • AK 微众银行 9.3 笔试 Java后端方向
  • 了解java中的通配符“?“
  • 浙大陈越何钦铭数据结构07-图6 旅游规划【最小堆实现】
  • OpenShift 4 - 用 Prometheus 和 Grafana 监视用户应用定制的观测指标(视频)
  • 【LeetCode】剑指 Offer <二刷>(3)
  • Ceph IO流程及数据分布
  • Netty-NIO
  • 红外物理学习笔记 ——第三章
  • 使用 htmx 构建交互式 Web 应用
  • S32K324芯片学习笔记
  • htmx-使HTML更强大
  • Java学习之序列化