Shiro与Spring结合时报Configuration error: No realms have been configured! One or more realms must be……

本文主要是介绍Shiro与Spring结合时报Configuration error: No realms have been configured! One or more realms must be……,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述
最近在跟着网上的教学视频学习Shiro安全框架,使用Shiro可以方便的做验证、授权等,其中在谈到使用多realm做验证,授权时,报了个缺少realm配置的错误。
Configuration error: No realms have been configured! One or more realms must be present to execute an authorization operation.] with root cause

为什么我会特别写出来这个问题呢?

其实这个问题我当时就解决了,更换了写realms属性的地方,但问题是在学习多realm身份验证时这两个地方都可以写realms属性,偏偏在经过了身份验证,再进行授权时却出现No realms have been configured!。
同时,我也看了下其他的博客,相同问题解决的办法就是securityManager里面authenticator的属性要放在realms属性前面,我尝试了在securityManager里面authenticator的属性放在了realms属性后面,身份验证失败,但是并没有报错。我就更加疑惑了……
没学过Shiro框架的人需要对realm概念先有个大致了解:
realm:就目前我的认识来简单描述下,realm就是一个验证器或者叫关卡,你输入username和password,生成一个UsernamePassswordToken,然后这个token给了某个realm,经过它的比对,通过就验证成功,不通过就验证失败。
多realm验证就可以理解成想要完成身份验证,需要通过多个realm的验证,可能每个realm都有自己的验证策略,最终是否验证成功的判断默认的有三种,比如通过全部的realm验证才算真正通过身份验证,或者通过任意一个realm也算是通过身份验证。

我先把主要的代码陈列下,做几个对比分析下:

applicationConetxt.xml配置文件

1.realms属性直接配置在securityManager里面

1).realms属性是在authenticator属性后面,身份验证、授权完全没有问题
 <bean id="securityManager" class="org.apache.shiro.web.mgt.DefaultWebSecurityManager"><property name="cacheManager" ref="cacheManager"/><property name="authenticator" ref="authenticator"/><property name="realms"><list><ref bean="jdbcRealm"></ref><ref bean="secondRealm"></ref></list></property></bean><!--多Realm认证--><bean id="authenticator" class="org.apache.shiro.authc.pam.ModularRealmAuthenticator"><!--认证策略--><property name="authenticationStrategy"><bean class="org.apache.shiro.authc.pam.AllSuccessfulStrategy"></bean></property></bean>
2).realms属性是在authenticator属性前面,经测试,身份验证不通过,但不会报错
 <bean id="securityManager" class="org.apache.shiro.web.mgt.DefaultWebSecurityManager"><property name="cacheManager" ref="cacheManager"/><property name="realms"><list><ref bean="jdbcRealm"></ref><ref bean="secondRealm"></ref></list></property><property name="authenticator" ref="authenticator"/></bean><!--多Realm认证--><bean id="authenticator" class="org.apache.shiro.authc.pam.ModularRealmAuthenticator"><!--认证策略--><property name="authenticationStrategy"><bean class="org.apache.shiro.authc.pam.AllSuccessfulStrategy"></bean></property></bean>

2.realms属性不配置在securityManager里面,而配置在authenticator里面

经过测试,身份验证时没有问题

 <bean id="securityManager" class="org.apache.shiro.web.mgt.DefaultWebSecurityManager"><property name="cacheManager" ref="cacheManager"/><property name="authenticator" ref="authenticator"/></bean><!--多Realm认证--><bean id="authenticator" class="org.apache.shiro.authc.pam.ModularRealmAuthenticator"><property name="realms"><list><ref bean="jdbcRealm"></ref><ref bean="secondRealm"></ref></list></property><!--认证策略--><property name="authenticationStrategy"><bean class="org.apache.shiro.authc.pam.AllSuccessfulStrategy"></bean></property></bean>

但在授权时就出现了报错:java.lang.IllegalStateException: Configuration error: No realms have been configured! One or more realms must be present to execute an authorization operation.

翻看了源代码发现:
报错的类路径为:

org.apache.shiro.authc.pam.ModularRealmAuthenticator#assertRealmsConfigured

在这里插入图片描述
我最大的疑惑来了……在做多realm身份验证时通过了,就证明配置在authenticator的多个realm确实被加载了,否则在身份验证时就应该报错!
既然能加载多realm,授权时为何又报错?

目前还没找到问题所在,先记在这里,害怕之后就忘了……

这篇关于Shiro与Spring结合时报Configuration error: No realms have been configured! One or more realms must be……的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/162808

相关文章

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

SpringBoot整合liteflow的详细过程

《SpringBoot整合liteflow的详细过程》:本文主要介绍SpringBoot整合liteflow的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...  liteflow 是什么? 能做什么?总之一句话:能帮你规范写代码逻辑 ,编排并解耦业务逻辑,代码

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

Spring 框架之Springfox使用详解

《Spring框架之Springfox使用详解》Springfox是Spring框架的API文档工具,集成Swagger规范,自动生成文档并支持多语言/版本,模块化设计便于扩展,但存在版本兼容性、性... 目录核心功能工作原理模块化设计使用示例注意事项优缺点优点缺点总结适用场景建议总结Springfox 是

在Spring Boot中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr

深度解析Spring Boot拦截器Interceptor与过滤器Filter的区别与实战指南

《深度解析SpringBoot拦截器Interceptor与过滤器Filter的区别与实战指南》本文深度解析SpringBoot中拦截器与过滤器的区别,涵盖执行顺序、依赖关系、异常处理等核心差异,并... 目录Spring Boot拦截器(Interceptor)与过滤器(Filter)深度解析:区别、实现

Springboot如何正确使用AOP问题

《Springboot如何正确使用AOP问题》:本文主要介绍Springboot如何正确使用AOP问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录​一、AOP概念二、切点表达式​execution表达式案例三、AOP通知四、springboot中使用AOP导出

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

springboot整合TDengine全过程

《springboot整合TDengine全过程》:本文主要介绍springboot整合TDengine全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录环境准备JDBC-JNI方式准备依赖实体类Mapper配置类测试类RESTful方式实体类配置类测试类总结