架构实战项目心得(十一):基于spring-security-oauth2的mysql数据表设计

一、建立数据库及数据表结构

  1 CREATE SCHEMA IF NOT EXISTS `oauth2` DEFAULT CHARACTER SET utf8 ;
  2 USE `oauth2` ;
  3 
  4 -- -----------------------------------------------------
  5 -- Table `oauth2`.`clientdetails`
  6 -- -----------------------------------------------------
  7 CREATE TABLE IF NOT EXISTS `oauth2`.`clientdetails` (
  8   `appId` VARCHAR(128) NOT NULL,
  9   `resourceIds` VARCHAR(256) NULL DEFAULT NULL,
 10   `appSecret` VARCHAR(256) NULL DEFAULT NULL,
 11   `scope` VARCHAR(256) NULL DEFAULT NULL,
 12   `grantTypes` VARCHAR(256) NULL DEFAULT NULL,
 13   `redirectUrl` VARCHAR(256) NULL DEFAULT NULL,
 14   `authorities` VARCHAR(256) NULL DEFAULT NULL,
 15   `access_token_validity` INT(11) NULL DEFAULT NULL,
 16   `refresh_token_validity` INT(11) NULL DEFAULT NULL,
 17   `additionalInformation` VARCHAR(4096) NULL DEFAULT NULL,
 18   `autoApproveScopes` VARCHAR(256) NULL DEFAULT NULL,
 19   PRIMARY KEY (`appId`))
 20 ENGINE = InnoDB
 21 DEFAULT CHARACTER SET = utf8;
 22 
 23 
 24 -- -----------------------------------------------------
 25 -- Table `oatuh2`.`oauth_access_token`
 26 -- -----------------------------------------------------
 27 CREATE TABLE IF NOT EXISTS `oauth2`.`oauth_access_token` (
 28   `token_id` VARCHAR(256) NULL DEFAULT NULL,
 29   `token` BLOB NULL DEFAULT NULL,
 30   `authentication_id` VARCHAR(128) NOT NULL,
 31   `user_name` VARCHAR(256) NULL DEFAULT NULL,
 32   `client_id` VARCHAR(256) NULL DEFAULT NULL,
 33   `authentication` BLOB NULL DEFAULT NULL,
 34   `refresh_token` VARCHAR(256) NULL DEFAULT NULL,
 35   PRIMARY KEY (`authentication_id`))
 36 ENGINE = InnoDB
 37 DEFAULT CHARACTER SET = utf8;
 38 
 39 
 40 -- -----------------------------------------------------
 41 -- Table `oatuh2`.`oauth_approvals`
 42 -- -----------------------------------------------------
 43 CREATE TABLE IF NOT EXISTS `oauth2`.`oauth_approvals` (
 44   `userId` VARCHAR(256) NULL DEFAULT NULL,
 45   `clientId` VARCHAR(256) NULL DEFAULT NULL,
 46   `scope` VARCHAR(256) NULL DEFAULT NULL,
 47   `status` VARCHAR(10) NULL DEFAULT NULL,
 48   `expiresAt` DATETIME NULL DEFAULT NULL,
 49   `lastModifiedAt` DATETIME NULL DEFAULT NULL)
 50 ENGINE = InnoDB
 51 DEFAULT CHARACTER SET = utf8;
 52 
 53 
 54 -- -----------------------------------------------------
 55 -- Table `oatuh2`.`oauth_client_details`
 56 -- -----------------------------------------------------
 57 CREATE TABLE IF NOT EXISTS `oauth2`.`oauth_client_details` (
 58   `client_id` VARCHAR(128) NOT NULL,
 59   `resource_ids` VARCHAR(256) NULL DEFAULT NULL,
 60   `client_secret` VARCHAR(256) NULL DEFAULT NULL,
 61   `scope` VARCHAR(256) NULL DEFAULT NULL,
 62   `authorized_grant_types` VARCHAR(256) NULL DEFAULT NULL,
 63   `web_server_redirect_uri` VARCHAR(256) NULL DEFAULT NULL,
 64   `authorities` VARCHAR(256) NULL DEFAULT NULL,
 65   `access_token_validity` INT(11) NULL DEFAULT NULL,
 66   `refresh_token_validity` INT(11) NULL DEFAULT NULL,
 67   `additional_information` VARCHAR(4096) NULL DEFAULT NULL,
 68   `autoapprove` VARCHAR(256) NULL DEFAULT NULL,
 69   PRIMARY KEY (`client_id`))
 70 ENGINE = InnoDB
 71 DEFAULT CHARACTER SET = utf8;
 72 
 73 
 74 -- -----------------------------------------------------
 75 -- Table `oatuh2`.`oauth_client_token`
 76 -- -----------------------------------------------------
 77 CREATE TABLE IF NOT EXISTS `oauth2`.`oauth_client_token` (
 78   `token_id` VARCHAR(256) NULL DEFAULT NULL,
 79   `token` BLOB NULL DEFAULT NULL,
 80   `authentication_id` VARCHAR(128) NOT NULL,
 81   `user_name` VARCHAR(256) NULL DEFAULT NULL,
 82   `client_id` VARCHAR(256) NULL DEFAULT NULL,
 83   PRIMARY KEY (`authentication_id`))
 84 ENGINE = InnoDB
 85 DEFAULT CHARACTER SET = utf8;
 86 
 87 
 88 -- -----------------------------------------------------
 89 -- Table `oatuh2`.`oauth_code`
 90 -- -----------------------------------------------------
 91 CREATE TABLE IF NOT EXISTS `oauth2`.`oauth_code` (
 92   `code` VARCHAR(256) NULL DEFAULT NULL,
 93   `authentication` BLOB NULL DEFAULT NULL)
 94 ENGINE = InnoDB
 95 DEFAULT CHARACTER SET = utf8;
 96 
 97 
 98 -- -----------------------------------------------------
 99 -- Table `oatuh2`.`oauth_refresh_token`
100 -- -----------------------------------------------------
101 CREATE TABLE IF NOT EXISTS `oauth2`.`oauth_refresh_token` (
102   `token_id` VARCHAR(256) NULL DEFAULT NULL,
103   `token` BLOB NULL DEFAULT NULL,
104   `authentication` BLOB NULL DEFAULT NULL)
105 ENGINE = InnoDB
106 DEFAULT CHARACTER SET = utf8;

 

转载于:https://www.cnblogs.com/laowangc/p/8882689.html

Spring Security OAuth2提供了一个基于数据库的认证和授权方案,可以使用SQL数据库来存储和管理用户信息和授权信息。 在Spring Security OAuth2中,可以使用JDBC来配置和管理数据库连接。需要配置数据源和相关的JDBC驱动,以便连接到SQL数据库。可以使用Spring Boot提供的自动配置功能来简化配置过程。 一般来说,需要创建一个具有特定结构的SQL数据库来存储用户和授权信息。Spring Security OAuth2提供了一组默认的结构,可以通过执行相应的SQL脚本来创建这些。这些包括:oauth_client_details、oauth_access_token、oauth_refresh_token等。 在配置文件中,需要指定数据库连接信息,如数据库URL、用户名、密码等。可以使用类似以下的配置来配置数据库连接: ``` spring.datasource.url=jdbc:mysql://localhost:3306/oauth2 spring.datasource.username=username spring.datasource.password=password spring.datasource.driver-class-name=com.mysql.jdbc.Driver ``` 同时,还需要配置相应的JDBC连接池和数据源,可以使用Spring Boot提供的自动配置功能,如下所示: ``` spring.datasource.tomcat.initial-size=5 spring.datasource.tomcat.max-idle=5 spring.datasource.tomcat.max-active=20 ``` 完成上述配置后,Spring Security OAuth2就可以使用SQL数据库来存储和管理用户信息和授权信息了。可以通过相关的API来进行用户认证和授权操作,例如获取访问令牌、刷新令牌等。 以上是关于Spring Security OAuth2在使用SQL数据库进行认证和授权的基本介绍,具体的配置和使用方法可以根据实际需求进行进一步调整和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值