Shiro 基于 ini 自定义 Realm

Shiro 基于 ini 自定义 Realm

基础环境

  • JDK 1.8
  • Maven 3

项目结构

目录结构.png

1、创建Maven项目并引入以下相关依赖

<dependencies>
  <dependency>
    <groupId>org.apache.shiro</groupId>
    <artifactId>shiro-core</artifactId>
    <version>1.4.0</version>
</dependency>
<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-nop</artifactId>
    <version>1.7.24</version>
  </dependency>
<!-- https://mvnrepository.com/artifact/commons-logging/commons-logging -->
<dependency>
    <groupId>commons-logging</groupId>
    <artifactId>commons-logging</artifactId>
    <version>1.2</version>
</dependency>

  <dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>3.8.1</version>
    <scope>test</scope>
  </dependency>
</dependencies>
2、Resource目录下创建配置文件 shiro.ini 并写入如下内容
[main]
securityManager=org.apache.shiro.mgt.DefaultSecurityManager
myRealm=com.negen.realm.MyRealm
securityManager.realms=$myRealm
3、test目录下创建测试类 ShiroTest.java
public class ShiroTest {
    @Test
    public void shiroTest() {
        //1、加载配置文件shiro.ini
        Factory<SecurityManager> factory = new IniSecurityManagerFactory("classpath:shiro.ini");
        //2、创建 SecurityManager 对象
        SecurityManager securityManager = factory.getInstance();
        //3、设置运行环境
        SecurityUtils.setSecurityManager(securityManager);
        //4、获取主体subject
        Subject subject = SecurityUtils.getSubject();
        //5、绑定主体登录账号及密码
//      UsernamePasswordToken token = new UsernamePasswordToken("test", "12356");     //账号不存在
//      UsernamePasswordToken token = new UsernamePasswordToken("admin", "123456");   //密码错误
        UsernamePasswordToken token = new UsernamePasswordToken("test", "123456");    //正确的账号及密码
        try {
            //6、登录
            subject.login(token);
            System.out.println("登录成功");
        }catch (UnknownAccountException unknownAccountException) {
            System.out.println("账号不存在");
        }catch (IncorrectCredentialsException incorrectCredentialsException) {
            System.out.println("密码错误");
        }
        //验证登录状态
        System.out.println("登录状态:" + subject.isAuthenticated());
    }
}
4、实现自定义Realm
  • 创建 MyRealm.java
  • 继承 AuthorizingRealm
  • 重写三个方法
/**
 * 自定义Realm
 * @author Negen
 *
 */
public class MyRealm extends AuthorizingRealm{
    @Override
        public String getName() {
            return "MyRealm";
        }

    /**
     *  授权
     */
    @Override
    protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principals) {
        return null;
    }

    /**
     *  身份认证
     */
    @Override
    protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken token) throws AuthenticationException {
        //获取登录时账号
        String userName = (String)token.getPrincipal();
        System.out.println(userName);
        if(!userName.equals("test"))
            throw new UnknownAccountException("账号不存在");
        //验证信息
        AuthenticationInfo info =
                new SimpleAuthenticationInfo("test", "123456", getName());
        return info;
    }
}
5、运行结果
运行结果.png
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 前言 前面的两篇博客使用了INI的形式完成了用户的认证授权操作.我曾经多次在博客中提到过INI文件形式进行认证授权...
    神经骚栋阅读 28,393评论 5 28
  • 一 、Shiro入门 1.简介 Apache Shiro 是 Java 的一个安全(权限)框架。 Shiro 可以...
    TiaNa_na阅读 4,719评论 0 8
  • 听雨和晓雪连忙冲了過去,這可不是鬧著玩的,二姐身体一向不好,如今又口吐鮮血,她們可都不想安琪出事。 剛上...
    逆暧阅读 3,146评论 2 1
  • "我会真诚的说谢谢,也会开心的向陌生人微笑。" 阳光此刻照在身上。
    晓烟浮阅读 472评论 0 1
  • (一) 大厨郭桐轩 家住道口大东关 开设桐家馆 (二) 且说清末年 八国联军北京犯 慈禧西安窜 (三) 返途滑州站...
    陈守玺阅读 2,087评论 0 4