SpringBoot:集成Shiro之Shiro标签(.jsp和.ftl)

绝地灬酷狼 2023-01-09 12:38 258阅读 0赞

09afb847119c8914de23269345baa503.png

前言


上一篇博客,我们说到如何在用户请求的时候,拦截用户请求进行操作,这一篇博客我们来聊一下如何使用Shiro标签在网页之中进行用户角色和权限控制.那么,我们就看一下具体的场景,假设页面当中有一个新增用户按钮,我们需要当拥有admin角色的用户登录认证完成之后显示,普通用户不显示,那么这时候我们就需要使用Shiro标签来做处理了.例如这个例子,我们就可以用一下代码来实现.如果含有admin就会显示,反之,则不会显示.

  1. <shiro:hashRole name = "admin">
  2. <button >新增用户</button>
  3. </shiro:hashRole>

JSP的Shiro标签


在JSP中使用Shiro标签比较简单,我们只需要注意用法即可.下面我就把所以Shiro标签放在下面了,各位看官自行查考.

  1. <shiro:guest>
  2. 游客访问 <a href = "login.jsp"></a>
  3. </shiro:guest>
  4. user 标签:用户已经通过认证\记住我 登录后显示响应的内容
  5. <shiro:user>
  6. 欢迎[<shiro:principal/>]登录 <a href = "logout">退出</a>
  7. </shiro:user>
  8. authenticated标签:用户身份验证通过,即 Subjec.login 登录成功 不是记住我登录的
  9. <shiro:authenticted>
  10. 用户[<shiro:principal/>] 已身份验证通过
  11. </shiro:authenticted>
  12. notAuthenticated标签:用户未进行身份验证,即没有调用Subject.login进行登录,包括"记住我"也属于未进行身份验证
  13. <shiro:notAuthenticated>
  14. 未身份验证(包括"记住我")
  15. </shiro:notAuthenticated>
  16. principal 标签:显示用户身份信息,默认调用
  17. Subjec.getPrincipal()获取,即Primary Principal
  18. <shiro:principal property = "username"/>
  19. hasRole标签:如果当前Subject有角色将显示body体内的内容
  20. <shiro:hashRole name = "admin">
  21. 用户[<shiro:principal/>]拥有角色admin
  22. </shiro:hashRole>
  23. hasAnyRoles标签:如果Subject有任意一个角色(或的关系)将显示body体里的内容
  24. <shiro:hasAnyRoles name = "admin,user">
  25. 用户[<shiro:pricipal/>]拥有角色admin 或者 user
  26. </shiro:hasAnyRoles>
  27. lacksRole:如果当前 Subjec没有角色将显示body体内的内容
  28. <shiro:lacksRole name = "admin">
  29. 用户[<shiro:pricipal/>]没有角色admin
  30. </shiro:lacksRole>
  31. hashPermission:如果当前Subject有权限将显示body体内容
  32. <shiro:hashPermission name = "user:create">
  33. 用户[<shiro:pricipal/>] 拥有权限user:create
  34. </shiro:hashPermission>
  35. lacksPermission:如果当前Subject没有权限将显示body体内容
  36. <shiro:lacksPermission name = "org:create">
  37. 用户[<shiro:pricipal/>] 没有权限org:create
  38. </shiro:lacksPermission>

Freemark的Shiro标签


在SpringBoot里面并不是直接支持JSP文件的,然后我就在项目中使用了Freemark,但是Shiro标签并不能直接支持.ftl文件,所以我们需要先引入一个Maven依赖.

  1. <dependency>
  2. <groupId>net.mingsoft</groupId>
  3. <artifactId>shiro-freemarker-tags</artifactId>
  4. <version>0.1</version>
  5. </dependency>

然后,我们写一个名为ShiroTagsFreeMarkerCfg配置类来对Freemark使用Shiro标签进行配置.当然了,要确定配置类能被正确注入到Bean中,代码如下所示.

  1. import com.jagregory.shiro.freemarker.ShiroTags;
  2. import freemarker.template.TemplateModelException;
  3. import org.springframework.beans.factory.annotation.Autowired;
  4. import org.springframework.stereotype.Component;
  5. import org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer;
  6. import javax.annotation.PostConstruct;
  7. @Component
  8. public class ShiroTagsFreeMarkerCfg {
  9. @Autowired
  10. private FreeMarkerConfigurer freeMarkerConfigurer;
  11. @PostConstruct
  12. public void setSharedVariable() throws TemplateModelException {
  13. freeMarkerConfigurer.getConfiguration().setSharedVariable("shiro", new ShiroTags());
  14. }
  15. }

配置类搞好之后,我们就可以在.ftl文件中使用Shiro的权限标签了,标签格式如下所示.

  1. <@shiro.guest>
  2. 游客访问 <a href = "login.jsp"></a>
  3. </@shiro.guest>
  4. user 标签:用户已经通过认证\记住我 登录后显示响应的内容
  5. <@shiro.user>
  6. 欢迎[<@shiro.principal/>]登录,<a href="/logout.html">退出</a>
  7. </@shiro.user>
  8. authenticated标签:用户身份验证通过,即 Subjec.login 登录成功 不是记住我登录的
  9. <@shiro.authenticated>
  10. 用户[<@shiro.principal/>]已身份验证通过
  11. </@shiro.authenticated>
  12. notAuthenticated标签:用户未进行身份验证,即没有调用Subject.login进行登录,包括"记住我"也属于未进行身份验证
  13. <@shiro.notAuthenticated>
  14. 当前身份未认证(包括记住我登录的)
  15. </@shiro.notAuthenticated>
  16. principal 标签:显示用户身份信息,默认调用
  17. Subjec.getPrincipal()获取,即Primary Principal
  18. <@shiro.principal property="username"/>
  19. hasRole标签:如果当前Subject有角色将显示body体内的内容
  20. <@shiro.hasRole name="admin">
  21. 用户[<@shiro.principal/>]拥有角色admin<br/>
  22. </@shiro.hasRole>
  23. hasAnyRoles标签:如果Subject有任意一个角色(或的关系)将显示body体里的内容
  24. <@shiro.hasAnyRoles name="admin,user,member">
  25. 用户[<@shiro.principal/>]拥有角色admin或user或member<br/>
  26. </@shiro.hasAnyRoles>
  27. lacksRole:如果当前 Subjec没有角色将显示body体内的内容
  28. <@shiro.lacksRole name="admin">
  29. 用户[<@shiro.principal/>]不拥有admin角色
  30. </@shiro.lacksRole>
  31. hashPermission:如果当前Subject有权限将显示body体内容
  32. <@shiro.hasPermission name="user:add">
  33. 用户[<@shiro.principal/>]拥有user:add权限
  34. </@shiro.hasPermission>
  35. lacksPermission:如果当前Subject没有权限将显示body体内容
  36. <@shiro.lacksPermission name="user:add">
  37. 用户[<@shiro.principal/>]不拥有user:add权限
  38. </@shiro.lacksPermission>

结语


写到这里,前前后后写了八篇Shiro集成博客,这个系列的博客到此就结束了,后期如果遇到新的问题会继续补充,欢迎继续关注骚栋.内心骚栋,未忘初心.

参考博客

Demo传送门

1cc773b3510614b54c92ffc3dc40d24a.gif

发表评论

表情:
评论列表 (有 0 条评论,258人围观)

还没有评论,来说两句吧...

相关阅读

    相关 shiro学习--jsp标签

    在页面上,如果要实现对某些文本、按钮等的控制,例如需要有什么角色或者权限才可以看见这个按钮,利用shiro自带的shiro标签能很容易就实现 一、引入shiro标签库