shiro使用注解式和jsp标签的方式进行开发

原文地址:https://blog.csdn.net/oppoppoppo/article/details/55215731

原先的时候可以使用url的shiro配置方式进行拦截,但是发现url地址过多会配置繁琐,解决的方式就是使用aop注解式和jsp标签进行开发

原来的方式

 

 
  1. <!-- Shiro权限过滤过滤器定义 -->

  2. <bean name="shiroFilterChainDefinitions" class="java.lang.String">

  3. <!-- 每个标签都是对应一个过滤器 比如anno对应的就是AnonymousFilter -->

  4. <constructor-arg>

  5. <value>

  6. ${adminPath}/sysindex.html = anon

  7. /static/** = anon

  8. <!-- 对应某个链接需要某个权限 取消这种url使用AOP注解

  9. ${adminPath}/queryArea.do = perms[items:query]

  10. -->

  11. ${adminPath}/login = authc

  12. <!-- 请求这个地址直接退出并清除session -->

  13. ${adminPath}/logout = logout

  14. ${adminPath}/** = user

  15. </value>

  16. </constructor-arg>

  17. </bean>

变成注解式

 

 

 
  1. @RequiresPermissions("sys:menu:save")

  2. @RequestMapping(value = "save")

  3. public void save(Menu menu, Model model, HttpServletRequest request, HttpServletResponse response) throws UnsupportedEncodingException {


那么这个Permission是怎么进行设置的呢

 

答案在授权方法中

 

 
  1. @Override

  2. protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principals) {

  3. //返回什么值是必须要和doGetAuthenticationInfo的第一个参数有关的

  4. Principal principal = (Principal) getAvailablePrincipal(principals);

  5. // 获取当前已登录的用户

  6. /* if (!PublicConstant.TRUE.equals(Global.getConfig("user.multiAccountLogin"))){

  7. Collection<Session> sessions = cachingShiroSessionDao.getActiveSessions(true, principal, SysUtils.getSession());

  8. if (sessions.size() > 0){

  9. // 如果是登录进来的,则踢出已在线用户

  10. if (SysUtils.getSubject().isAuthenticated()){

  11. for (Session session : sessions){

  12. cachingShiroSessionDao.delete(session);

  13. }

  14. }

  15. // 记住我进来的,并且当前用户已登录,则退出当前用户提示信息。

  16. else{

  17. SysUtils.getSubject().logout();

  18. throw new AuthenticationException("msg:账号已在其它地方登录,请重新登录。");

  19. }

  20. }

  21. }*/

  22. try{

  23. User user = userService.get(new User(principal.getLoginName()));

  24. if (user != null) {

  25. SimpleAuthorizationInfo info = new SimpleAuthorizationInfo();

  26. //加入权限即可以在jsp和java类中调用

  27. // List<Menu> list = SysUtils.getRoleMenu();

  28. // for (Menu menu : list){

  29. // if (StringUtils.isNotBlank(menu.getPermission())){

  30. // // 添加基于Permission的权限信息

  31. // for (String permission : StringUtils.split(menu.getPermission(),",")){

  32. // info.addStringPermission(permission);

  33. // }

  34. // }

  35. // }

  36. // 添加用户权限

  37. info.addStringPermission("user");

  38. // 更新登录IP和时间

  39. // iUserApi.updateUserLoginInfo(user);

  40. // 记录登录日志

  41. // LogUtils.saveLog(Servlets.getRequest(), "系统登录");

  42. return info;

  43. }

  44. }catch(Exception e){

  45. logger.error("DEMO 报错-位置:[SystemAuthorizingRealm->doGetAuthorizationInfo]",e);

  46. }

  47. return null;

  48. }

 

info.addStringPermission(permission);

这样就完成了对应

 

spring开启aop 两种配置方式

 

 
  1. <!-- AOP式方法级权限检查 -->

  2. <bean class="org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator" depends-on="lifecycleBeanPostProcessor">

  3. <property name="proxyTargetClass" value="true" />

  4. </bean>

  5. <bean class="org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor">

  6. <property name="securityManager" ref="securityManager"/>

  7. </bean>

 
  1. <!-- 开启aop,对类代理 -->

  2. <aop:config proxy-target-class="true"></aop:config>

  3. <!-- 开启shiro注解支持 -->

  4. <bean

  5. class="

  6. org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor">

  7. <property name="securityManager" ref="securityManager" />

  8. </bean>


用一种即可

 

jsp标签

 

Jsp页面添加:

<%@ tagliburi="http://shiro.apache.org/tags" prefix="shiro" %>或者自定义shiro标签

 

标签名称

标签条件(均是显示标签内容)

<shiro:authenticated>

登录之后

<shiro:notAuthenticated>

不在登录状态时

<shiro:guest>

用户在没有RememberMe时

<shiro:user>

用户在RememberMe时

<shiro:hasAnyRoles name="abc,123" >

在有abc或者123角色时

<shiro:hasRole name="abc">

拥有角色abc

<shiro:lacksRole name="abc">

没有角色abc

<shiro:hasPermission name="abc">

拥有权限资源abc

<shiro:lacksPermission name="abc">

没有abc权限资源

<shiro:principal>

显示用户身份名称

 <shiro:principal property="username"/>     显示用户身份中的属性值

 

注意:无论是jsp还是aop都会每次都调用realm进行访问数据库获取权限信息

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值