SpringSecurity框架简介及与shiro特点对比

作者:字母哥博客 时间:2023-01-03 13:56:25 

前言

本专栏内容目前已经比较系统了,核心内容也相对完整,本系列文章会根据Spring Security社区的发展逐步的更新内容。请大家多多关注脚本之家~

一、 SpringSecurity 框架简介

官网:https://spring.io/projects/spring-security

Spring Security 是强大的,且容易定制的,基于Spring开发的实现认证登录与资源授权的应用安全框架。

SpringSecurity 的核心功能:

  • Authentication:身份认证,用户登陆的验证(解决你是谁的问题)

  • Authorization:访问授权,授权系统资源的访问权限(解决你能干什么的问题)

  • 安全防护,防止跨站请求,session 攻击等

二、比较一下shiro与Spring Security

目前在java web应用安全框架中,与Spring Security形成直接竞争的就是shiro,二者在核心功能上几乎差不多,但从使用的角度各有优缺点。笔者认为:没有最好的,只有最合适的。

2.1.用户量

Shiro的使用量一直高于spring security。但是从趋势上来看(2020年10月的百度指数),Spring Security是在一直上升的,shiro的使用量同比、环比都进入了下滑期。

SpringSecurity框架简介及与shiro特点对比

2.2.使用的方便程度

通常来说,shiro入门更加容易,使用起来也非常简单,这也是造成shiro的使用量一直高于Spring Security的主要原因。但是从笔者的角度来看,二者其实都简单,我说说我的理由:

  • 在没有Spring Boot之前,Spring Security的大部分配置要通过XML实现,配置还是还是非常复杂的。但是有了 Spring Boot之后,这一情况已经得到显著改善。

  • Spring Security之所以看上去比shiro更复杂,其实是因为它引入了一些不常用的概念与规则。大家应该都知道2/8法则,这在Spring Security里面体现的特别明显,如果你只学Spring Security最重要的那20%,这20%的复杂度和shiro基本是一致的。也就是说,不重要的那80%,恰恰是Spring Security比shiro的“复杂度”。

也就是说,如果有人能帮你把Spring Security最重要的那20%摘出来,二者的入门门槛、复杂度其实是差不太多的。

2.3.社区支持

Spring Security依托于Spring庞大的社区支持,这点自不必多说。shiro属于apache社区,因为它的广泛使用,文档也非常的全面。二者从社区支持来看,几乎不相上下。

但是从社区发展的角度看,Spring Security明显更占优势,随着Spring Cloud、Spring Boot、Spring Social的长足进步,这种优势会越来越大。因为Spring Security毕竟是Spring的亲儿子,Spring Security未来在于Spring系列框架集成的时候一定会有更好的融合性,前瞻性、兼容性!这也是为什么我们要学Spring Security的主要原因!

2.4.功能丰富性

Spring Security因为它的复杂,所以从功能的丰富性的角度更胜一筹。其中比较典型的如:

  • Spring Security默认含有对OAuth2.0的支持,与Spring Social一起使用完成社交媒体登录也比较方便。shiro在这方面只能靠自己写代码实现。

  • 还有一种普遍说法:Spring Security在网络安全的方面下的功夫更多,但是笔者并未有非常直接的感受,有可能出现安全问题的时候才会感到不够安全的痛。

三、总结

如果你只是想实现一个简单的web应用,shiro更加的轻量级,学习成本也更低。如果您正在开发一个分布式的、微服务的、或者与Spring Cloud系列框架深度集成的项目,笔者还是建议您使用Spring Security。

来源:https://www.kancloud.cn/hanxt/springsecurity/1212463

标签:SpringSecurity,shiro,框架简介
0
投稿

猜你喜欢

  • python 类的继承 实例方法.静态方法.类方法的代码解析

    2021-12-19 14:19:34
  • 在import scipy.misc 后找不到 imsave的解决方案

    2023-08-09 05:21:45
  • 详解python学习笔记之解释器

    2023-09-15 15:28:26
  • 详解TensorFlow训练网络两种方式

    2021-06-24 00:18:23
  • python调用fortran模块

    2023-12-22 23:36:40
  • python回调函数的使用方法

    2023-05-28 02:50:55
  • Python爬虫之urllib库详解

    2022-01-09 23:03:27
  • 如何避免asp的SQL的执行效率低

    2009-01-08 18:18:00
  • 利用Python实现自动工作汇报的脚本分享

    2022-05-31 10:55:37
  • 如何让python的运行速度得到提升

    2023-04-26 21:48:35
  • 网页栅格系统研究:蛋糕的切法

    2008-10-24 17:07:00
  • python使用requests模块实现爬取电影天堂最新电影信息

    2021-02-21 22:44:44
  • Python学习笔记之抓取某只基金历史净值数据实战案例

    2021-08-14 20:28:13
  • Python 实现某个功能每隔一段时间被执行一次的功能方法

    2021-11-14 09:57:25
  • python数据结构之面向对象

    2021-04-09 08:02:06
  • 完美处理python与anaconda环境变量的冲突问题

    2023-01-11 07:37:31
  • 多种还原.bak数据库文件方式

    2008-02-25 13:51:00
  • 在Python反编译中批量pyc转 py的实现代码

    2023-08-11 20:21:04
  • Python使用post及get方式提交数据的实例

    2023-06-25 05:52:35
  • python 计算方位角实例(根据两点的坐标计算)

    2023-08-01 09:30:54
  • asp之家 网络编程 m.aspxhome.com