我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎么解决springboot+shiro+thymeleaf页面级元素的权限控制问题

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎么解决springboot+shiro+thymeleaf页面级元素的权限控制问题

今天小编给大家分享一下怎么解决springboot+shiro+thymeleaf页面级元素的权限控制问题的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

    springboot+shiro+thymeleaf页面级元素的权限控制

    我用的springboot2.1版本。

    学习了很多大神的总结,基本上都是一样的,shiro权限框架,前端验证是为jsp设计的,其中的tag只能用于jsp系列的模板引擎。

    使用了thymeleaf作为前端模板引擎,使用HTML文件,没法引入shiro的tag lib,此时如果要使用shiro的话,可以引入 thymeleaf-extras-shiro.jar这个拓展包来曲线实现shiro的前端验证。

    在pom.xml中加入如下依赖:

    <dependency>   <groupId>com.github.theborakompanioni</groupId>   <artifactId>thymeleaf-extras-shiro</artifactId>   <version>1.2.1</version></dependency>

    然后在配置shiro的configuration时,加入

    @Beanpublic ShiroDialect shiroDialect() {   return new ShiroDialect();}

    然后在需要控制的页面元素的页面头上加上xmlns:

    <!DOCTYPE html><html lang="en" xmlns:th="http://www.thymeleaf.org"      xmlns:shiro="http://www.pollix.at/thymeleaf/shiro"><head>    <meta charset="UTF-8">    <title>Add</title></head><body><h4>用户添加界面</h4><p shiro:hasRole="admin"> 有权限</p><p shiro:hasRole="test">无权限</p></body></html>

    其他的配置,和shiro用于后台权限控制的配置一样,然后就可以了,事实上我也是这样做的,但是遇到一个问题,

    一直报这个异常

    org.springframework.beans.factory.BeanCreationException:Error creating bean with name 'shiroDialect' defined in class path resource[com/gaox/config/ShiroConfig.class]: Bean instantiation via factory methodfailed; nested exception is org.springframework.beans.BeanInstantiationException:Failed to instantiate [at.pollux.thymeleaf.shiro.dialect.ShiroDialect]: Factorymethod 'shiroDialect' threw exception; nested exception isjava.lang.NoClassDefFoundError:org/thymeleaf/processor/attr/AbstractTextChildModifierAttrProcessor
           atorg.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:587)~[spring-beans-5.0.5.RELEASE.jar:5.0.5.RELEASE]
           atorg.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1250)~[spring-beans-5.0.5.RELEASE.jar:5.0.5.RELEASE]
           atorg.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1099)~[spring-beans-5.0.5.RELEASE.jar:5.0.5.RELEASE]
           atorg.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:541)~[spring-beans-5.0.5.RELEASE.jar:5.0.5.RELEASE]
           atorg.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:501)~[spring-beans-5.0.5.RELEASE.jar:5.0.5.RELEASE]
           atorg.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:317)~[spring-beans-5.0.5.RELEASE.jar:5.0.5.RELEASE]
           atorg.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:228)~[spring-beans-5.0.5.RELEASE.jar:5.0.5.RELEASE]
           atorg.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:315)~[spring-beans-5.0.5.RELEASE.jar:5.0.5.RELEASE]
           atorg.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:199)~[spring-beans-5.0.5.RELEASE.jar:5.0.5.RELEASE]
           atorg.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:760)~[spring-beans-5.0.5.RELEASE.jar:5.0.5.RELEASE]
           atorg.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:869)~[spring-context-5.0.5.RELEASE.jar:5.0.5.RELEASE]
           atorg.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:550)~[spring-context-5.0.5.RELEASE.jar:5.0.5.RELEASE]
           atorg.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:140)~[spring-boot-2.0.1.RELEASE.jar:2.0.1.RELEASE]
           atorg.springframework.boot.SpringApplication.refresh(SpringApplication.java:759)[spring-boot-2.0.1.RELEASE.jar:2.0.1.RELEASE]
           atorg.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:395)[spring-boot-2.0.1.RELEASE.jar:2.0.1.RELEASE]
           atorg.springframework.boot.SpringApplication.run(SpringApplication.java:327)[spring-boot-2.0.1.RELEASE.jar:2.0.1.RELEASE]
           atorg.springframework.boot.SpringApplication.run(SpringApplication.java:1255)[spring-boot-2.0.1.RELEASE.jar:2.0.1.RELEASE]
           atorg.springframework.boot.SpringApplication.run(SpringApplication.java:1243)[spring-boot-2.0.1.RELEASE.jar:2.0.1.RELEASE]
           atcom.gaox.ShiroDemoApplication.main(ShiroDemoApplication.java:10) [classes/:na]

    这个异常是说找不到AbstractTextChildModifierAttrProcessor这个类,事实上是这个类是有的,只是在编译的时候能找到,所以没有异常,在运行的时候找不到这个类,所以就异常了,仔细检查了好多遍,最后我改了springboot的版本,然后就不报错了,开始我使用的是最新2.0版本,改到1.5就正常了

    下面贴一下关于shiro用到的包

    希望遇到同样问题的同学绕过个坑

    <dependency>   <groupId>org.apache.shiro</groupId>   <artifactId>shiro-core</artifactId>   <version>1.3.2</version></dependency><dependency>   <groupId>org.apache.shiro</groupId>   <artifactId>shiro-spring</artifactId>   <version>1.4.0</version></dependency><dependency>   <groupId>org.apache.shiro</groupId>   <artifactId>shiro-ehcache</artifactId>   <version>1.2.5</version></dependency><dependency>   <groupId>com.github.theborakompanioni</groupId>   <artifactId>thymeleaf-extras-shiro</artifactId>   <version>1.2.1</version></dependency>

    shiro整合thymeleaf常见权限控制标签使用

    未认证并且未记住的用户

    <!-- 当前用户是否为“游客”,如果是未认证,也未记住的用户,那么就显示该 p 标签中的内容 --><p shiro:guest="">Please <a href="login.html" rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >login</a></p>

    未认证,已记住的用户

    <!-- 未认证的用户但已记住,与下面的 authenticated 标签相对应。    与 guest 标签的区别是,该标签包含已记住用户。 --><p shiro:notAuthenticated="">    Please <a href="login.html" rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >login</a> in order to update your credit card information.</p>

    认证通过或已记住的用户

    <!-- 认证通过或已记住的用户,则显示该 p 标签中的内容 --><p shiro:user="">    Welcome back John! Not John? Click <a href="login.html" rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >here</a> to login.</p>

    认证通过,未记住的用户

    <!-- 已认证通过,但未记住的用户。这是与 user 标签的区别所在。 --><p shiro:authenticated="">    Hello, <span shiro:principal=""></span>, how are you today?</p><a shiro:authenticated="" href="updateAccount.html" rel="external nofollow" >Update your contact information</a>

    当前用户信息

    <!-- 输出当前用户信息,通常为登录帐号信息 --><p>Hello, <shiro:principal />, how are you today?</p>

    验证当前用户是否具有该角色

    <!-- 验证当前用户是否具有该 admin 角色,若拥有,则显示 a 标签的内容 --><a shiro:hasRole="admin" href="admin.html" rel="external nofollow" >Administer the system</a>

    验证当前用户是否不具有该角色

    <!-- 与 hasRole 标签逻辑相反,当用户不属于该 developer 角色时显示 --><p shiro:lacksRole="developer">    Sorry, you are not allowed to developer the system.</p>

    验证当前用户是否同时具有以下所有角色

    <!-- 验证当前用户是否同时具有以下所有角色 --><p shiro:hasAllRoles="developer, product">    You are a developer and a admin.</p>

    验证当前用户是否具于以下任意一个角色

    <!-- 验证当前用户是否具于以下任意一个角色 --><p shiro:hasAnyRoles="admin, vip, developer">    You are a admin, vip, or developer.</p>

    验证当前用户是否拥有指定权限

    <!-- 验证当前用户是否拥有 update 权限 --><a shiro:hasPermission="update" href="createUser.html" rel="external nofollow" >添加用户</a>

    验证当前用户是否不拥有指定权限

    <!-- 与 hasPermission 标签逻辑相反,当前用户不拥有指定权限 delete --><p shiro:lacksPermission="delete">    Sorry, you are not allowed to delete user accounts.</p>

    验证当前用户是否同时拥有以下所有角色

    <!-- 验证当前用户是否同时拥有以下所有角色 --><p shiro:hasAllPermissions="add, update">    You can see or add users.</p>

    验证当前用户是否拥有以下任意一个权限

    <!-- 验证当前用户是否拥有以下任意一个权限 --><p shiro:hasAnyPermissions="add, update, delete">    You can see or delete users.</p>

    以上就是“怎么解决springboot+shiro+thymeleaf页面级元素的权限控制问题”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网行业资讯频道。

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    怎么解决springboot+shiro+thymeleaf页面级元素的权限控制问题

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档

    猜你喜欢

    怎么解决springboot+shiro+thymeleaf页面级元素的权限控制问题

    今天小编给大家分享一下怎么解决springboot+shiro+thymeleaf页面级元素的权限控制问题的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获
    2023-06-29

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录