Shiro授权详解

在进行Shiro授权之前,了解相关术语对于理解整个过程至关重要。Shiro的授权机制以角色为中心,辅以权限,来控制主体对资源的访问。以下是常用术语的简要介绍:

  • 授权 (Authorization)
    授权是指确定主体是否有权访问某一资源或执行某一操作。通过角色和权限机制,Shiro为系统提供了细粒度的访问控制能力

  • 主体 (Subject)
    主体是指当前的用户、设备或其他能与应用进行交互的实体。每个主体在登录后,会被分配一定的权限和角色来确定其行为

  • 资源 (Resource)
    资源可以是系统中的任意数据或服务,例如文件、API接口等,主体通过权限来访问这些资源

  • 权限 (Permission)
    权限是允许主体执行某个具体操作的规则。Shiro的权限是基于字符串的,可以通过自定义规则实现不同的访问控制策略

  • 角色 (Role)
    角色是权限的集合,主体通过被分配某些角色来获得一系列权限。例如,一个"管理员"角色可能包含创建、更新、删除等权限

  • 隐式角色 (Implicit Role)
    隐式角色是指由系统规则自动分配的角色,无需明确配置。通常基于上下文、属性等信息动态确定

  • 显式角色 (Explicit Role)
    显式角色是通过明确配置的角色,例如在数据库中定义或直接在代码中指定的角色

1. 授权

授权是Shiro中重要的核心功能,通过角色和权限实现系统的安全控制

(1) 授权流程

Shiro的授权过程分为以下几步:

  1. 主体登录
    主体通过身份验证(认证)后,进入授权流程。Shiro通过Subject对象获取当前用户信息

  2. 权限检查
    当主体尝试访问某一资源时,Shiro首先通过SecurityManager查询该主体的权限信息。系统会根据配置的Realm来判断主体是否有权限

  3. 角色检查
    若主体的权限不足,Shiro还会查询主体所属的角色,检查该角色是否具备访问资源的权限

  4. 结果返回
    根据查询结果,Shiro决定是否允许主体访问对应资源。如果授权失败,Shiro会抛出UnauthorizedException异常

(2) 授权方式

Shiro支持多种授权方式,满足不同系统需求

  1. 基于角色的授权
    通过角色为主体赋予一组权限,这种方式适合结构清晰、权限划分明确的场景

    subject.hasRole("admin") //判断主体是否拥有“admin”角色
  1. 基于权限的授权
    直接为主体赋予特定的权限,通常使用字符串标识权限,具有高度灵活性

    subject.isPermitted("file:read")//判断主体是否具备“文件读取”的权限
  2. 基于注解的授权
    Shiro还提供了注解方式,通过注解可以直接在控制器、服务方法中指定授权规则

    @RequiresRoles("admin") 或 @RequiresPermissions("user:update")
2. SpringBoot+Shiro授权

将Shiro与SpringBoot集成是目前比较主流的实践,通过简单的配置即可为SpringBoot项目增加灵活的授权控制

(1) 静态授权

静态授权是指在代码或配置文件中提前定义好角色和权限的关系,不依赖运行时动态数据。这种方式适合权限结构简单的场景

  1. 配置静态授权规则
    在Shiro的配置文件中为不同角色配置权限:

    shiro:roles:admin: "file:create,file:read,file:update"user: "file:read"
    
  2. 代码中基于角色或权限的判断
    在代码中可以使用以下方式进行静态授权:

     System.out.println("调用MyShiroRealm的doGetAuthorizationInfo获取权限信息");//获得权限信息User user = (User) principalCollection.getPrimaryPrincipal();SimpleAuthorizationInfo info = new SimpleAuthorizationInfo();info.addRole(user.getRole().getRoleName());info.addStringPermission("用户列表");//管理增删改if ("管理员".equals(user.getRole().getRoleName())) {info.addStringPermission("用户添加");info.addStringPermission("用户编辑");info.addStringPermission("用户删除");}
(2) 动态授权

动态授权通过数据库或外部服务来实现对权限的实时控制。此方式更加灵活,适合权限体系复杂、需要频繁调整权限的场景

  1. 动态角色与权限的加载
    通过自定义Realm从数据库中加载角色和权限:

    System.out.println("调用MyShiroRealm的doGetAuthenticationInfo获取身份信息");
    //获得身份信息
    UsernamePasswordToken token = (UsernamePasswordToken) authenticationToken;
    String usrName = token.getUsername();
    User user = userService.getUserByUsrName(usrName);
    if (user == null) {throw new AuthenticationException();//账号错误
    }
    if (user.getUsrFlag() == null || user.getUsrFlag().intValue() == 0) {throw new LockedAccountException();//账号被禁用
    }
    SimpleAuthenticationInfo info = new SimpleAuthenticationInfo(user,user.getUsrPassword(),getName());

  2. 结合动态数据判断
    使用动态方式可以根据业务需求实时调整权限,例如根据用户角色动态生成权限菜单

    Subject currentUser = SecurityUtils.getSubject();// 动态判断用户是否有管理员角色
    if (currentUser.hasRole("admin")) {return "你好admin";
    } else {return "角色不存在!";
    }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/57520.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

uni-app写的微信小程序如何体积太大如何处理

方法一:对主包进行分包处理,将使用url: /pages/components/equipment/equipment跳转页面的全部拆分为分包,如url: /pagesS/components/equipment/equipment 在pages.json中添加 "subPackages": [{ "root"…

2024年五一杯数学建模C题煤矿深部开采冲击地压危险预测求解全过程论文及程序

2024年五一杯数学建模 C题 煤矿深部开采冲击地压危险预测 原题再现: “煤炭是中国的主要能源和重要的工业原料。然而,随着开采深度的增加,地应力增大,井下煤岩动力灾害风险越来越大,严重影响着煤矿的安全高效开采。在…

transient关键字详解

今天没打算写blog,在看一篇关于多线程环境下SimpleDateFormat线程不安全的问题,一般我们都知道多线程下这个是不安全,但是为什么不安全不太清楚,我在看的这篇文章讲的比较透彻,我根据文章中讲结合SimpleDateFormat源码…

[Unity Demo]从零开始制作空洞骑士Hollow Knight第十五集:制作更多地图,更多敌人,更多可交互对象

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、第一个代表性场景 1.制作更多敌人2.制作更多可交互对象二、第二个代表性场景 1.制作更多敌人2.制作更多可交互对象三、第三个代表性场景 1.制作更多敌人2.制…

苹果手机照片误删还能恢复吗?3款数据恢复工具推荐

照片是人们记录生活点滴与美好回忆的重要方式之一。而苹果手机则具备了较强的拍照功能,深受市场欢迎,但其也存在误删照片并难以恢复的难题。现在市面上也又很多照片恢复软件,其功能参差不齐。今天,小编为您找到了3款高效且可靠的苹…

猫咪掉毛上岸!一招解决清理难题——好用的宠物空气净化器

养宠前就知道猫咪有换毛季,我了解的是一年有两次,养宠后才知道,一次是半年...秋天风大的时候更加严重,直接就是一只“蒲公英”,随时散落一地的猫毛。早晚给它梳毛,每次都能收获巨大一张猫饼。 家里的地板上…

高标准农田信息化推动农业产业链升级

在当前全球农业转型的关键时期,高标准农田信息化作为现代农业发展的核心驱动力之一,正深刻地影响并推动着农业产业链的全面升级。这一进程不仅关乎粮食安全与质量的提升,更是实现农业可持续发展、促进农村经济繁荣的重要途径。 技术应用&…

TCL中环开工率下滑,员工集体要求解约赔偿

“ 尽管中环的市占率有所提高,但是高开工率也带来了巨量硅片库存,严重拖累了公司业绩。 ” 转载:科技新知 原创 作者丨依蔓 编辑丨蕨影 因大幅下调开工率,光伏硅片龙头TCL中环疑似遭遇员工“离职潮”? 近日&…

Java EE规范

1、简介 Java EE的全称是Java Platform, Enterprise Edition。早期Java EE也被称为J2EE,即Java 2 Platform Enterprise Edition的缩写。从J2EE1.5以后,就改名成为Java EE。一般来说,企业级应用具备这些特征:1、数据量特别大&…

curl支持ssl报错:SSL certificate problem: unable to get local issuer certificate

1. 说明 在使用curl时返回CURLE_OUT_OF_MEMORY,猜想可能是ssl的问题,用curl命令做实验发现访问http没问题,访问https会有问题,根据打印log判断是缺少证书,需要下载证书并声明证书路径。 1.1 curl访问http 访问正常&…

计算机网络基础进阶

三次握手四次挥手 三次握手 1------建立连接----------------------2 ACK1,seq0 2------传输数据,建立连接---------1 1------传输数据,建立连接---------2 三次握手用于建立TCP连接,确保通信双方都准备好进行数据传输。整个…

Gin 协程mysql客户端

一、Gin框架 mysql配置 这里选择yaml文件配置 二、配置读取 viper 读取yaml文件中对应配置 三、mysql 的协程客户端 文件位置 package databaseimport ("database/sql""fmt""github.com/spf13/viper""log""net/http"&quo…

鸿蒙_基础

HarmonyOS基础 页面跳转 import { router } from kit.ArkUIButton(去首页).onClick(()>{router.pushUrl({ // 普通跳转,可以返回url:pages/Index}) }) Button(登录).onClick(()>{router.replaceUrl({ // 替换跳转,无法返回&#xff0…

Zabbix进阶实战!将告警推送到Syslog服务器详细教程

需求场景: 用户需要将zabbix产生的告警事件推送给rsyslog服务器,syslog服务器再对事件日志进行分析处理. 环境配置信息 服务器 IP地址 ZabbixServer 192.168.200.195 Rsyslog服务器 192.168.200.128 *Rsyslog服务器防火墙需要放通 UDP/514端口 推送脚本…

C#描述-计算机视觉OpenCV(7):MSER特征检测

C#描述-计算机视觉OpenCV(7):MSER特征检测 基本概念操作实例效果优化 基本概念 前文C#描述-计算机视觉OpenCV(6):形态学描述了如何对图像的前后景特征形态进行检测与运算,本篇将分析基于形态的…

CANoe与C#联合仿真方案

引言 CANoe作为一款强大的网络仿真工具,能够模拟各种通信协议,尤其是在汽车领域的CAN、LIN、Ethernet等协议。而C#作为一种广泛使用的编程语言,能够为CANoe提供灵活的用户界面和逻辑控制。本文将探讨如何将CANoe与C#结合,实现高效的联合仿真方案。 1. 系统架构 联合仿真…

秋招突击——8/6——万得数据面试总结

文章目录 引言正文面经整理一1、讲一下java的多态,重载,重写的概念,区别2、说一下Java的数组,链表的结构,优缺点3、创建java线程的方式有哪些,具体说说4、创建线程池呢、每个参数的意义5、通过那几种方式保…

软件测试工程师:如何写出好的测试用例?

软件测试用例(Test Case)是软件测试过程中的一种详细文档或描述,用于描述在特定条件下,对软件系统或组件进行测试的步骤、输入数据、预期输出和预期行为。编写高质量的测试用例是确保软件质量的关键步骤之一。以下是一些编写优秀测试用例的建议&#xff…

如何快速解决谷歌网站页面收录难题?

在外贸网站的运营中,页面无法被谷歌收录是一个常见的困扰。即便你的内容再优秀,如果搜索引擎的爬虫无法抓取到你的页面,那一切努力都将白费。而GPC爬虫池服务可以帮助你快速解决网站页面的收录问题。它通过千万级的爬虫池资源,强力…

数据结构与算法:贪心算法与应用场景

目录 11.1 贪心算法的原理 11.2 经典贪心问题 11.3 贪心算法在图中的应用 11.4 贪心算法的优化与扩展 总结 数据结构与算法:贪心算法与应用场景 贪心算法是一种通过选择当前最佳解来构造整体最优解的算法策略。贪心算法在很多实际问题中都取得了良好的效果&am…