博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Spring Shiro
阅读量:6944 次
发布时间:2019-06-27

本文共 2599 字,大约阅读时间需要 8 分钟。

hot3.png

Shiro的组件都是JavaBean/POJO式的组件,所以非常容易使用Spring进行组件管理,可以非常方便的从ini配置迁移到Spring进行管理,且支持JavaSE应用及Web应用的集成。

JavaSE应用

spring-shiro.xml提供了普通JavaSE独立应用的Spring配置:

可以看出,只要把之前的ini配置翻译为此处的spring xml配置方式即可,无须多解释。LifecycleBeanPostProcessor用于在实现了Initializable接口的Shiro bean初始化时调用Initializable接口回调,在实现了Destroyable接口的Shiro bean销毁时调用 Destroyable接口回调。如UserRealm就实现了Initializable,而DefaultSecurityManager实现了Destroyable。具体可以查看它们的继承关系。

 

Web应用

Web应用和普通JavaSE应用的某些配置是类似的,此处只提供一些不一样的配置,详细配置可以参考spring-shiro-web.xml。 

配置信息:

 

1、sessionIdCookie是用于生产Session ID Cookie的模板;

2、会话管理器使用用于web环境的DefaultWebSessionManager;

3、安全管理器使用用于web环境的DefaultWebSecurityManager。 

 

Shiro权限注解

Shiro提供了相应的注解用于权限控制,如果使用这些注解就需要使用AOP的功能来进行判断,如Spring AOP;Shiro提供了Spring AOP集成用于权限注解的解析和验证。

为了测试,此处使用了Spring MVC来测试Shiro注解,当然Shiro注解不仅仅可以在web环境使用,在独立的JavaSE中也是可以用的,此处只是以web为例了。

 

在spring-mvc.xml配置文件添加Shiro Spring AOP权限注解的支持: 

如上配置用于开启Shiro Spring AOP权限注解的支持;<aop:config proxy-target-class="true">表示代理类。

 

接着就可以在相应的控制器(AnnotationController)中使用如下方式进行注解: 

@RequiresRoles("admin")  @RequestMapping("/hello2")//访问hello2方法的前提是当前用户有admin角色。  public String hello2() {      return "success";  }

 

 

当验证失败,其会抛出UnauthorizedException异常,此时可以使用Spring的ExceptionHandler(DefaultExceptionHandler)来进行拦截处理:

@ExceptionHandler({UnauthorizedException.class})  @ResponseStatus(HttpStatus.UNAUTHORIZED)  public ModelAndView processUnauthenticatedException(NativeWebRequest request, UnauthorizedException e) {      ModelAndView mv = new ModelAndView();      mv.addObject("exception", e);      mv.setViewName("unauthorized");      return mv;  }

如果集成Struts2,需要注意《Shiro+Struts2+Spring3 加上@RequiresPermissions 后@Autowired失效》问题:

 

权限注解      

@RequiresAuthentication  

表示当前Subject已经通过login进行了身份验证;即Subject. isAuthenticated()返回true。 

@RequiresUser  

表示当前Subject已经身份验证或者通过记住我登录的。

@RequiresGuest  

表示当前Subject没有身份验证或通过记住我登录过,即是游客身份。  

@RequiresRoles(value={“admin”, “user”}, logical= Logical.AND)  

表示当前Subject需要角色admin和user。

@RequiresPermissions (value={“user:a”, “user:b”}, logical= Logical.OR)  

表示当前Subject需要权限user:a或user:b。  

转载于:https://my.oschina.net/shichangcheng/blog/802604

你可能感兴趣的文章
Docker容器互联
查看>>
Linux基础知识--文件操作
查看>>
java+jsp+mysql网页制作总结(3)
查看>>
DAY6-小变化(java提示框)-2018-1-16
查看>>
mysql在表的某一位置增加一列、删除一列、修改列名
查看>>
iOS 网络与多线程--3.异步Get方式的网络请求(非阻塞)
查看>>
Excel相同内容如何设置相同的背景色
查看>>
LCA问题
查看>>
计算机基础知识
查看>>
论文学习及报告总结
查看>>
Oracle中创建含有Date时间的字段的表
查看>>
《1024伐木累》-炒股赚钱,大保健
查看>>
HTML5秘籍(第2版) 中文pdf扫描版
查看>>
51nod 1179 最大的最大公约数
查看>>
201521460001网络攻防实验
查看>>
使用Apache pdfbox: 从Linux安装字体到log4j设置日志级别
查看>>
结构体
查看>>
iOS9新框架—Watch Connectivity(详情:http://ios.itcast.cn/subject/ios9/index.shtml )
查看>>
1、线性表实现:顺序存储
查看>>
linux下重命名文件的命令
查看>>