栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

SpringSecurity授权

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

SpringSecurity授权

文章目录
  • 授权简介
    • Spring Security对授权的定义
    • Spring Security授权原理
  • Spring Security授权
    • 内置权限表达式

授权简介

用户认证指的是不管是用户名密码,还是图形验证码,最终的目的都是让系统知道到底是谁在访问你的系统,解决的问题是:你是谁。

本篇文章的内容主要讲解你能在系统中做什么事情,针对这个有的叫做授权, 有的叫做鉴权, 还有的叫权限控制。最终的目的就是你能够在系统中做什么。

Spring Security对授权的定义

安全权限控制问题其实就是控制能否访问URL。

Spring Security授权原理

在我们应用系统里面,如果想要控制用户权限,需要有两部分数据:

  • 系统配置信息:写着系统里面有哪些URL,每一个url拥有哪些权限才允许被访问。
  • 用户权限信息:请求用户拥有的权限
    • 系统用户发送一个请求:系统配置信息和用户权限信息作比对,如果比对成功则允许访问。

当一个系统授权规则比较简单,基本不变的时候,系统的权限配置信息可以写在我们的代码里面。比如前台门户网站等权限比较单一,使用简单的授权配置即可完成;如果权限复杂,例如办公OA,电商后台管理系统等就不能写在代码里面了,需要RBAC权限模型设计。

Spring Security授权 内置权限表达式

Spring Security 使用Spring EL来支持,主要用于Web访问和方法安全上,可以通过表达式来判断是否具有访问权限。

下面是Spring Security常用的内置表达式。expressionUrlAuthorizationConfigurer定义了所有的表达式。

表达式说明
permitAll指定任何人都允许访问
denyAll指定任何人都不允许访问
anonymous指定匿名用户允许访问
rememberMe指定已记住的用户允许访问
authenticated指定任何经过身份验证的用户都允许访问,不包含anonymous
fullyAuthenticated指定由经过身份验证的用户允许访问,不包含anonymous和rememberMe
hasRole(role)指定需要特定的角色的用户允许访问,会自动在角色前面插入ROLE_
hasAnyRole([role1,role2])指定需要任意一个角色的用户允许访问,会自动在角色前面插入ROLE_
hasAuthority(authority)指定需要特定权限的用户允许访问
hasAnyAuthority([authority,authority])指定需要任意一个权限的用户允许访问
hasIpAddress(ip)指定需要特定的IP地址可以访问
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/462567.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号