一 . 介绍SpringSecurity
SpringSecurity是一个功能强大且高度可定制的身份验证和访问控制框架,它是保护基于Spring的应用程序的实际标准。
Spring Security是⼀个⾯向Java应⽤程序提供身份验证和安全性的框架。
与所有Spring项⽬⼀样,Spring Security的真正威⼒在于它可以轻松地扩展以满⾜定制需求。
应用程序安全性可以归结为差不多两个独立的问题:身份验证(你是谁?)
和授权(你可以做什么?)
在Spring Security
架构设计中,认证和授权 是分开的,⽆论使⽤什么样的认证⽅式
二. 权限管理
基本上涉及到⽤户参与的系统都要进⾏权限管理,权限管理属于系统安全的范畴,权限管理实现对⽤户访问系统的控制,按照安全规则或者安全策略控制⽤户可以访问⽽且只能访问⾃⼰被授权的资源。权限管理包括⽤户身份认证和授权两部分,简称认证授权。对于需要访问控制的资源⽤户⾸先经过身份认证,认证通过后⽤户具有该资源的访问权限⽅可访问。
也就是通过身份认证检查是否有进入系统的权利,通过授权检查是否有访问特定资源的权利。
1、认证
身份认证,就是判断⼀个⽤户是否为合法⽤户的处理过程。最常⽤的简单身份认证⽅式是系统通过核对⽤户输⼊的⽤户名和⼝令,看其是否与系统中存储的该⽤户的⽤户名和⼝令⼀致,来判断⽤户身份是否正确。
2、授权
授权,即访问控制,控制谁能访问哪些资源。主体进⾏身份认证后需要分配权限⽅可访问系统的资源,对于某些资源没有权限是⽆法访问的
三. 编写
1.加jar包
<!-- 加jar 就代表项目加上了安全框架 没有加这个jar就代表项目没有使用安全框架 --> <dependency> <groupId>org.springframework.boot