使用Shiro的JdbcRealm实现查询数据库进行身份认证

场景

Subject认证主体

Subject认证主体包含两个信息:

1.Principals:身份,可以是用户名,邮件,手机号码等,可以用来标识一个登录主体身份。

2.Credentials:凭证,常见有密码,数字证书等。

身份认证流程

Realm以及JDBC Realm

Realm意思是域,shiro从Realm中获取验证数据。

Realm有很多种,例如常见的jdbc realm、jndi realm、text realm。

jdbc realm:Shiro 提供了一个 JdbcRealm,它会默认去寻找 users, roles, permissions 三张表做类似于 DAO 中的查询。

实现

搭建数据库以及表

新建users表

插入users表数据

建表符合如上规范,shiro就会自动查询users表进行身份验证。

新建配置文件

resource下新建jdbc_realm.ini文件

[main]
jdbcRealm=org.apache.shiro.realm.jdbc.JdbcRealm
dataSource=com.mchange.v2.c3p0.ComboPooledDataSource
dataSource.driverClass=com.mysql.jdbc.Driver
dataSource.jdbcUrl=jdbc:mysql://localhost:3306/shirotest
dataSource.user=root
dataSource.password=123
jdbcRealm.dataSource=$dataSource
securityManager.realms=$jdbcRealm

注:

1.jdbcRealm是固定写。

2.dataSource设置数据源。

3.jdbcRealm.dataSource=$dataSource是使用上面刚声明的dataSource数据源。

进行身份验证

新建类JdbcRealmTest.java

package com.badao.shiro;

import org.apache.shiro.SecurityUtils;
import org.apache.shiro.authc.AuthenticationException;
import org.apache.shiro.authc.UsernamePasswordToken;
import org.apache.shiro.config.IniSecurityManagerFactory;
import org.apache.shiro.mgt.SecurityManager;
import org.apache.shiro.subject.Subject;
import org.apache.shiro.util.Factory;

public class JdbcRealmTest {
 
public static void main(String[] args) {
  
  //读取配置文件,初始化化SecurityManager工厂
  Factory<SecurityManager> factory = new IniSecurityManagerFactory("classpath:jdbc_realm.ini");
  //获取securityManager实例
  SecurityManager securityManager = factory.getInstance();
  //将securityManager实例绑定到SecurityUtils
  SecurityUtils.setSecurityManager(securityManager);
  //获取当前用户
  Subject currentUser = SecurityUtils.getSubject();
  //创建token令牌,用户名 密码
  UsernamePasswordToken token = new UsernamePasswordToken("badao","12");
  try {
   //身份认证 登录 
   currentUser.login(token);
   System.out.println("身份认证成功");
  } catch (AuthenticationException e) {
   e.printStackTrace();
   System.out.println("身份认证失败");
  }
  //退出
  currentUser.logout();
  
 }
}

效果

输入错误

输入正确

源码下载

https://download.csdn.net/download/badao_liumang_qizhi/11171730

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

霸道流氓气质

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值