【shiro】shiro学习笔记2-自定义realm

上一篇中使用的realm是shiro自带的realm,SecurityManager调用了IniRealm来进行认证。
但开发中大部分是要自己实现realm的逻辑的
环境
jar包

pom.xml

<dependencies>
  <!-- shiro -->
  <dependency>
 <groupId>org.apache.shiro</groupId>
 <artifactId>shiro-core</artifactId>
 <version>1.2.4</version>
 </dependency>

  <!--日志问题的解决-->
  <dependency>
 <groupId>org.slf4j</groupId>
 <artifactId>slf4j-log4j12</artifactId>
 <version>1.7.15</version>
 </dependency>

  <!--日志-->
  <dependency>
 <groupId>commons-logging</groupId>
 <artifactId>commons-logging</artifactId>
 <version>1.2</version>
 </dependency>
 <dependency> 

 <groupId>junit</groupId>
 <artifactId>junit</artifactId>
 <version>4.12</version>
 <scope>test</scope>
 </dependency>

</dependencies>
目录结构

目录结构

代码
自定义realm

CustomRealm.java

package xyz.mrwood.study.realm;

import org.apache.shiro.authc.AuthenticationException;
import org.apache.shiro.authc.AuthenticationInfo;
import org.apache.shiro.authc.AuthenticationToken;
import org.apache.shiro.authc.SimpleAuthenticationInfo;
import org.apache.shiro.authz.AuthorizationInfo;
import org.apache.shiro.realm.AuthorizingRealm;
import org.apache.shiro.subject.PrincipalCollection;

import java.util.HashMap;
import java.util.Map;

public class CustomRealm extends AuthorizingRealm {

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

    // 认证
  @Override
  protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken authenticationToken) throws AuthenticationException {

        //获得主体(帐号)
  String principal = (String) authenticationToken.getPrincipal();
  //获得凭证(密码)
  String credentials = new String((char[]) authenticationToken.getCredentials());

  //模拟数据库
  Map<String, String> users = new HashMap<>();
  users.put("kiwi", "123456");
  users.put("fly", "1111");
  users.put("kimi", "17536");
  users.put("kiki", "123456");

  //判断帐号是否存在
  if (users.containsKey(principal)) {

            return new SimpleAuthenticationInfo(principal, users.get(principal), getName());
  } else {
            return null;
  }
    }
}
认证程序

AuthenticationTest.java

@Test
  public void testCustomRealm(){

// 构造SecurityManager环境
  Factory<SecurityManager> factory = new IniSecurityManagerFactory("classpath:shiro-realm.ini");
  SecurityManager securityManager = factory.getInstance();

// 设置SecurityManager到运行环境中
  SecurityUtils.setSecurityManager(securityManager);

// 构造主体对象
  Subject subject = SecurityUtils.getSubject();

// 构造认证的token对象
  AuthenticationToken token = new UsernamePasswordToken("kiwi", "12345");

// 主体执行登录认证
  try {
            subject.login(token);
  } catch (AuthenticationException e) {
            e.printStackTrace();
  }

        System.out.println("认证:" + subject.isAuthenticated());
  }
shiro配置文件

shiro-realm.ini

[main]
customRealm = xyz.mrwood.study.realm.CustomRealm
#注入自定义的realm,很像spring的注入,注意这个$符号
securityManager.realms = $customRealm
日志文件

log4j.properties

log4j.rootLogger=DEBUG, stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n
总结
  1. 自定义realm通常继承org.apache.shiro.realm.AuthorizingRealm类,要实现两个方法
    doGetAuthorizationInfo(授权逻辑),doGetAuthenticationInfo(认证逻辑),实现相应的方法
  2. 通过方法的入参authenticationToken可以获得用户输入的帐号与密码,如果找不到这个帐号就返回null,如果找到就返回AuthenticationInfo对象,其中帐号是用户输入的帐号,密码是数据库中对应的密码。密码的验证工作由上一层自动完成
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值