shiro三 认证+授权 实战

Shiro 一 简介
Shrio 二 ssm+shiro整合

摘要:

这篇文章主要用Navicate Premium 自带的shiro 数据库 来测试 认证和授权的流程。

一 认证

1、配置
  <bean id="shiroFilter" class="org.apache.shiro.spring.web.ShiroFilterFactoryBean">
        <property name="securityManager" ref="securityManager"/>
        <!-- 过虑器链定义,从上向下顺序执行,一般将/**放在最下边 -->
      <property name="loginUrl" value="/login"></property>
       <property name="filterChainDefinitions">
            <value>
                /logout=logout
                <!--认证的过滤器-->
                /refuse=anon
                /images/**=anon
                /js/**=anon
                /styles/**=anon
        <!--  所有url 必须通过认证才能访问-->
                /**=authc
            </value>
        </property>
    </bean>
  <!-- securityManager安全管理器 -->
    <bean id="securityManager" class="org.apache.shiro.web.mgt.DefaultWebSecurityManager">
        <property name="realm" ref="customRealm"/>
    </bean>
 <!-- realm -->
    <bean id="customRealm" class="com.zl.shiro.DemoShiro">
        <property name="credentialsMatcher" ref="credentialsMatcher"/>
    </bean>

    <!-- 凭证匹配器 -->
    <bean id="credentialsMatcher"
          class="org.apache.shiro.authc.credential.HashedCredentialsMatcher">
        <property name="hashAlgorithmName" value="md5"/>
        <property name="hashIterations" value="1"/>
    </bean>

2、DemoShiro (包含授权)

public class DemoShiro extends AuthorizingRealm {
    @Autowired
    UsersMapper usersMapper;
    @Autowired
    SysPermissionMapper sysPermissionMapper;

    @Override
    public String getName() {
        return "DemoShiro";
    }

    @Override
    protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken authenticationToken) throws AuthenticationException {
        System.out.println("从数据库查询用户,进行认证");
        String principal = (String) authenticationToken.getPrincipal();
        Users users = usersMapper.selectByPrimaryKey(principal);
        if (users == null) {
            return null;
        }
        String password = users.getPassword();
        String salt = users.getSalt();
        return new SimpleAuthenticationInfo(users, password, ByteSource.Util.bytes(salt), getName());
    }

    @Override
    protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principalCollection) {
        System.out.println("从数据库查询权限进行授权");
        Users users = (Users) principalCollection.getPrimaryPrincipal();
        String id = users.getId();
        List<String> strings = sysPermissionMapper.listPercode(id);
        SimpleAuthorizationInfo authorizationInfo = new SimpleAuthorizationInfo();
        authorizationInfo.addStringPermissions(strings);
        return authorizationInfo;
    }

}

3、login 接口

  // 用户登陆提交
   @RequestMapping("/login")
   public String loginsubmit(Model model, HttpServletRequest request)
           throws Exception {

       // shiro在认证过程中出现错误后将异常类路径通过request返回
       String exceptionClassName = (String) request
               .getAttribute("shiroLoginFailure");
       if (exceptionClassName != null) {
           if (UnknownAccountException.class.getName().equals(exceptionClassName)) {
               throw new CustomException("账号不存在");
           } else if (IncorrectCredentialsException.class.getName().equals(
                   exceptionClassName)) {
               throw new CustomException("用户名/密码错误");
           } else if ("randomCodeError".equals(exceptionClassName)) {
               throw new CustomException("验证码错误");
           } else {
               //最终在异常处理器生成未知错误
               throw new Exception();
           }
       }
       return "login";

   }

4、表单提交

<form action="/login" method="post">
    用户名: <input type="text" name="username">
    密码: <input type="password" name="password"><br><br><br>
    <input type="submit" value="提交">
</form>

认证成功自动返回上一路径

二 授权

1、开启aop 注解支持(加在spring-mvc 配置文件中)

 <mvc:annotation-driven/>
    <!-- 开启aop,对类代理 -->
    <aop:config proxy-target-class="true"></aop:config>
    <!-- 开启shiro注解支持 -->
    <bean
            class="
org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor">
        <property name="securityManager" ref="securityManager" />
    </bean>

2、注解授权

  @RequestMapping("/permission")
    @RequiresPermissions("item:create")
    @ExceptionHandler(UnauthorizedException.class)
    public String permission() {
        return "authorationzation";
    }

3、jsp 页面中 授权

<%@ taglib uri="http://shiro.apache.org/tags" prefix="shiro" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>认证成功</title>
</head>
<body>
<h3>认证成功</h3>
<shiro:hasPermission name="item:query">
    <a href="/permission">有查询权限:查询用户信息</a>
</shiro:hasPermission>
</body>
</html>

友情提示

授权 当没有权限时,会抛出无权访问 异常
处理异常:

@Component
public class CustomExceptionResolver implements HandlerExceptionResolver {
 @Override
    public ModelAndView resolveException(HttpServletRequest request,
      HttpServletResponse response, Object handler, Exception ex) {
        //输出异常
        ex.printStackTrace();

        if (ex instanceof UnauthorizedException) {
                // 跳转到拒绝页面
             ModelAndView mv = new ModelAndView("refuse");
            return mv;
        }
    }
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,402评论 6 499
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,377评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,483评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,165评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,176评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,146评论 1 297
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,032评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,896评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,311评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,536评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,696评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,413评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,008评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,659评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,815评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,698评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,592评论 2 353

推荐阅读更多精彩内容