• Shiro 简单介绍和快速入门。


    一、shiro是啥?

    /*
    * Shiro ?
      安全框架是一个
      1.功能强大且易于使用的Java安全框架,可执行身份验证,授权,加密和会话管理,并可用于保护任何应用程序 - 从命令行应用程序,移动应用程序到最大的Web和企业应用程序。
      2.Shiro提供了应用程序安全API来执行以下方面(我喜欢将这些称为应用程序安全性的4个基石):
    
    1.身份验证  Authentication  证明用户的部分,称为用户的“登录”。
    2.授权      Authorization   访问控制
    3.密码学    Cryptography    保护或隐藏窥探数据的数据
    4.会话管理  Session Message  每个用户时间敏感状态。
    
    工作流程?
    Application Code.
    1.subject  封装信息。
        抽象的用户;登录系统的用户
        将用户交给SecurityManager 管理。处理
    
    2.SecurityManager: 安全管理器。
        核心。
    
        2.1门面模式?
        用户-----代理-----具体的功能。(根据需要找具体的功能呢)
    
    3.Realms :领域。  相等于shiro和应用程序安全数据之间的  连接器。
    
    
    流程梳理?
    1.获取用户名和密码
    2.通过subject封装 将用户交给SecurityManager 管理。处理
    3.SecurityManager  安全管理器----->不同的子项管理器
    4.通过Realm 实现shiro和数据源的联系
                ini   保存数据的配置文件  不用连接数据库  模拟用户存储数据库信息。
    
    * */

    二、创建一个java工程的maven项目。 导入相关jar包

    <?xml version="1.0" encoding="UTF-8"?>
    
    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
      <modelVersion>4.0.0</modelVersion>
    
      <groupId>com.aaa</groupId>
      <artifactId>DemoShiro</artifactId>
      <version>1.0-SNAPSHOT</version>
    
      <name>DemoShiro</name>
      <!-- FIXME change it to the project's website -->
      <url>http://www.example.com</url>
    
      <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <maven.compiler.source>1.7</maven.compiler.source>
        <maven.compiler.target>1.7</maven.compiler.target>
        <spring.version>5.1.1.RELEASE</spring.version>
      </properties>
    
      <dependencies>
        <dependency>
          <groupId>junit</groupId>
          <artifactId>junit</artifactId>
          <version>4.11</version>
          <scope>test</scope>
        </dependency>
    
        <!--引入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-ehcache</artifactId>
          <version>1.3.2</version>
        </dependency>
        <dependency>
          <groupId>org.apache.shiro</groupId>
          <artifactId>shiro-spring</artifactId>
          <version>1.3.2</version>
        </dependency>
        <dependency>
          <groupId>org.apache.shiro</groupId>
          <artifactId>shiro-web</artifactId>
          <version>1.3.2</version>
        </dependency>
    
        <!--解决Spring使用slf4j输出日志与log4j冲突的问题-->
        <dependency>
          <groupId>org.slf4j</groupId>
          <artifactId>slf4j-log4j12</artifactId>
          <version>1.6.6</version>
        </dependency>
        <!-- log4j的包 -->
        <dependency>
          <groupId>org.slf4j</groupId>
          <artifactId>slf4j-api</artifactId>
          <version>1.6.6</version>
        </dependency>
        <dependency>
          <groupId>log4j</groupId>
          <artifactId>log4j</artifactId>
          <version>1.2.16</version>
        </dependency>
      </dependencies>
    
      <build>
        <pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) -->
          <plugins>
            <!-- clean lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#clean_Lifecycle -->
            <plugin>
              <artifactId>maven-clean-plugin</artifactId>
              <version>3.1.0</version>
            </plugin>
            <!-- default lifecycle, jar packaging: see https://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_jar_packaging -->
            <plugin>
              <artifactId>maven-resources-plugin</artifactId>
              <version>3.0.2</version>
            </plugin>
            <plugin>
              <artifactId>maven-compiler-plugin</artifactId>
              <version>3.8.0</version>
            </plugin>
            <plugin>
              <artifactId>maven-surefire-plugin</artifactId>
              <version>2.22.1</version>
            </plugin>
            <plugin>
              <artifactId>maven-jar-plugin</artifactId>
              <version>3.0.2</version>
            </plugin>
            <plugin>
              <artifactId>maven-install-plugin</artifactId>
              <version>2.5.2</version>
            </plugin>
            <plugin>
              <artifactId>maven-deploy-plugin</artifactId>
              <version>2.8.2</version>
            </plugin>
            <!-- site lifecycle, see https://maven.apache.org/ref/current/maven-core/lifecycles.html#site_Lifecycle -->
            <plugin>
              <artifactId>maven-site-plugin</artifactId>
              <version>3.7.1</version>
            </plugin>
            <plugin>
              <artifactId>maven-project-info-reports-plugin</artifactId>
              <version>3.0.0</version>
            </plugin>
          </plugins>
        </pluginManagement>
      </build>
    </project>

    三,在SRC下新建资源目录resources ,添加两个配置文件。

    1.log4j.properties 外部配置文件

    2.ini   常用的一种保存数据的配置文件 

    这两份文件可以在shiro的官网上下载。

     四、测试效果。   Quickstart  这个类文件也是直接在官网上下载以后,直接拿过来用的。 

    package com.zxf;
    
    import org.apache.shiro.SecurityUtils;
    import org.apache.shiro.authc.*;
    import org.apache.shiro.config.IniSecurityManagerFactory;
    import org.apache.shiro.mgt.SecurityManager;
    import org.apache.shiro.session.Session;
    import org.apache.shiro.subject.Subject;
    import org.apache.shiro.util.Factory;
    import org.slf4j.Logger;
    import org.slf4j.LoggerFactory;
    
    public class Quickstart {
        //获取日志对象
        private static final transient Logger log = LoggerFactory.getLogger(Quickstart.class);
        
        public static void main(String[] args) {
    //        加载配置文件
            Factory<SecurityManager> factory = new IniSecurityManagerFactory("classpath:shiro.ini");
            
            //获取安全管理器对象
            SecurityManager securityManager = factory.getInstance();
            SecurityUtils.setSecurityManager(securityManager);
            
            //获取当前的用户信息  工具类获取  直接调用
            Subject currentUser = SecurityUtils.getSubject();
            
            //模拟会话管理
            Session session = currentUser.getSession();
            session.setAttribute("user", "张三");
    
            //取出值
            String value = (String) session.getAttribute("user");
            if (value.equals("张三")) {
                log.info("Retrieved the correct value! [" + value + "]");
            }
            
    //        判断当前用户是否已经认证
            if (!currentUser.isAuthenticated()) {
    
                //用户名密码令牌     UserNamePasswordToken  令牌
                UsernamePasswordToken token = new UsernamePasswordToken("lonestarr", "vespa");
    
                //记住我   是否记住
                token.setRememberMe(true);
                try {
                    //调用登录方法   然后交给管理器
                    //调用Suject.login方法 ---》安全管理器--->认证器 ,授权器
                    currentUser.login(token);
                } catch (UnknownAccountException uae) {//账号不存在
                    log.info("账号不存在" + token.getPrincipal());
                } catch (IncorrectCredentialsException ice) {//密码错误
                    log.info("密码错误 " + token.getPrincipal() + " was incorrect!");
                } catch (LockedAccountException lae) {//账号锁死
                    log.info("The account for username " + token.getPrincipal() + " is locked.  " +
                            "Please contact your administrator to unlock it.");
                }
                catch (AuthenticationException ae) {
                }
            }
            //都正确 就提示登录成功。
            log.info("用户登录 [" + currentUser.getPrincipal() + "] logged in successfully.");
    
            //授权验证:  模拟角色
            if (currentUser.hasRole("schwartz")) {
                log.info("May the Schwartz be with you!");
            } else {
                log.info("Hello, mere mortal.");
        }
            //模拟权限
            if (currentUser.isPermitted("lightsaber:weild")) {
                log.info("You may use a lightsaber ring.  Use it wisely.");
            } else {
                log.info("Sorry, lightsaber rings are for schwartz masters only.");
            }
    
            if (currentUser.isPermitted("winnebago:drive:eagle5")) {
                log.info("You are permitted to 'drive' the winnebago with license plate (id) 'eagle5'.  " +
                        "Here are the keys - have fun!");
            } else {
                log.info("Sorry, you aren't allowed to drive the 'eagle5' winnebago!");
            }
    
            //模拟注销
            //all done - log out!
            currentUser.logout();
    
            System.exit(0);
        }
    }
  • 相关阅读:
    JavaScript中对事件简单的理解
    正则表达式 RE模块
    模块
    面向对象进阶
    元类详细解释
    四.面向对象和函数补充
    四.函数
    Python的基础知识:
    五层协议及tcp三次握手四次挥手
    nginx常见错误
  • 原文地址:https://www.cnblogs.com/ZXF6/p/11341420.html
Copyright © 2020-2023  润新知