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

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

时间:2023-03-24 17:38:37浏览次数:44  
标签:jdbc import org Shiro dataSource 查询数据库 apache JdbcRealm shiro


场景

Subject认证主体

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

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

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

身份认证流程

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

Realm以及JDBC Realm

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

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

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

实现

搭建数据库以及表

新建users表

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

插入users表数据

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

建表符合如上规范,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();
  
 }
}

效果

输入错误

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

输入正确

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


 

标签:jdbc,import,org,Shiro,dataSource,查询数据库,apache,JdbcRealm,shiro
From: https://blog.51cto.com/BADAOLIUMANGQZ/6147500

相关文章

  • Sql Server中查询数据库所有表及其数据总条数和占用空间
    1、查询某数据库中的所有数据表SELECTname数据表FROMsysobjectsWHERExtype='u'ORDERBYname2、查询某数据库中的所有数据表及其数据总条数SELECTa.name数据表,......
  • shiro框架
    核心概念:Subject,SecurtiyManager,RealmsSubject:正在与软件交互的事物(可以是人,可以是第三方进程等等)SecurityManager:管理所有所有用户相关安全的操作,如果是web应用会设......
  • shiro-550反序列化漏洞分析
    0x00环境搭建首先下载有漏洞的版本https://codeload.github.com/apache/shiro/zip/refs/tags/shiro-root-1.2.4配置samples/web的pom文件配置tomcat配置......
  • Shiro自定义Realm实现认证
       7.4.2 自定义Realm      ......
  • 查询数据库中的所有学生或员工信息,出现乱码时
    1.在测试计划中建立一个线程,再建立一个http请求和一个查看结果树2.在http请求中填写需要用到的信息   3。执行该http请求,在就察看结果树上显示的信息时乱码; ......
  • Shiro认证入门程序
    7.2 Shiro认证7.2.1 Shiro认证流程    7.2.2 Shiro入门程序工程环境                        ......
  • MySQL查询数据库所有表名及其注释
    1、查看Mysql数据库"ori_data"下所有表的表名、表注释及其数据量SELECTTABLE_NAME表名,TABLE_COMMENT表注释,TABLE_ROWS数据量FROMinformation_schema.tablesWHERE......
  • go 下的查询数据库的框架 ORM框架:访问mysql数据库
    运维的基友习惯使用python了,学习go的时候是不是被gorm恶心死了例如pythonflask框架下的orm那么好用简单,或者号称世界上最好用的语言php的同学们也是非常的苦恼呢......
  • springboot整合shiro
    1.什么是ShiroShiro是一个基于Java的安全框架,它提供了身份验证、授权、加密和会话管理等安全功能,可以帮助Java应用程序实现安全性。2.根据Shiro的基本使用了解其基本......
  • Shiro架构
    作用shiro是认证、授权管理的框架。 核心组件   subject:用户,但不一定指的是人authenticator:认证器authorizer:授权器realm:用户的权限获取,一般通过与D......