自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

SpringBoot整合ShardingSphere5.x實現數據加解密功能

開發(fā) 前端
在config.yaml文件中我們配置了連接池信息,但是實際沒有生效。如上配置的最小連接數是10,最大是200,但是實際打印都成了默認值都是10。

準備環(huán)境

  • 添加依賴?
<dependency>
<groupId>org.apache.shardingsphere</groupId>
<artifactId>shardingsphere-jdbc-core</artifactId>
<version>${shardingsphere.version}</version>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>${mybatis-plus.version}</version>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>${mybatis-plus.version}</version>
</dependency>
  • 數據表users

圖片


  1. pwd:明文字段
  2. pwd_clipher:密文字段
  3. assisted_query_pwd:查詢輔助列
  • 配置文件

application.yml配置文件(Springboot)?

spring:
datasource:
driverClassName: org.apache.shardingsphere.driver.ShardingSphereDriver
url: jdbc:shardingsphere:classpath:config.yaml
name: EncryptHikariCP
---
mybatis-plus:
configuration:
mapUnderscoreToCamelCase: true
mapperLocations: classpath*:/mapper/**/*.xml
typeAliasesPackage: com.pack

config.yaml配置文件(ShardingSphere)?

#數據源配置
dataSources:
ds1:
dataSourceClassName: com.zaxxer.hikari.HikariDataSource
driverClassName: com.mysql.cj.jdbc.Driver
jdbcUrl: jdbc:mysql://localhost:3306/testjpa?serverTimeznotallow=GMT%2B8&useSSL=false
username: root
password: 123123
minimumIdle: 10
maximumPoolSize: 200
autoCommit: true
idleTimeout: 30000
poolName: MasterHikariCP
maxLifetime: 1800000
connectionTimeout: 30000
connectionTestQuery: SELECT 1
#規(guī)則配置
rules:
- !ENCRYPT #加解密相關配置
tables:
users:
columns:
pwd: #邏輯列(如果是老系統(tǒng)一般都會吧這個邏輯列和實際物理列名一致)
plainColumn: pwd #實際物理列名
cipherColumn: pwd_cipher #加密后的列名
encryptorName: pwd_encryptor #加密列使用的加密算法(對應下面的配置)
#assistedQueryColumn: assisted_query_pwd
#assistedQueryEncryptorName: assisted_encryptor
queryWithCipherColumn: true
encryptors:
pwd_encryptor:
type: SM4
props:
sm4-key: aaaabbbbccccdddd1111222233334444
sm4-mode: ECB
sm4-iv: aabbccddeeffgghh
sm4-padding: PKCS7Padding
assisted_encryptor:
type: SM3
props:
sm3-salt: aaaabbbb
#執(zhí)行時打印SQL
props:
sql-show: true

有了上面配置后,接下來就可以進行相應的CRUD操作了。

CRUD操作

實體對象?

@TableName("users")
public class Users {

@TableId(type = IdType.ASSIGN_ID)
private Long id;
private String name;
@TableField("id_no")
private String idNo ;
private Integer age;
private String email;
private String pwd ;
}

Mapper類?

public interface UsersMapper extends BaseMapper<Users> {

}

測試類?

@SpringBootTest
public class UserMapperTest {

@Resource
private UsersMapper usersMapper ;
@Resource
private IUsersService us ;
@Resource
private List<DataSource> dataSources ;

@Test
public void testUserList() {
QueryWrapper<Users> queryWrapper = new QueryWrapper<>() ;
queryWrapper.eq("pwd", "999999") ;
System.out.println(this.usersMapper.selectList(queryWrapper)) ;
}


@Test
public void testSave() {
Users user = new Users() ;
user.setAge(99) ;
user.setEmail("99999@qq.com") ;
user.setIdNo("999999") ;
user.setName("久久") ;
user.setPwd("999999") ;

this.usersMapper.insert(user) ;
}


}

測試結果

圖片


數據源及查詢輔助列

  • 數據源配置

在config.yaml文件中我們配置了連接池信息,但是實際沒有生效。如上配置的最小連接數是10,最大是200,但是實際打印都成了默認值都是10。最后修改連接池配置方式如下:?

spring:
datasource:
driverClassName: org.apache.shardingsphere.driver.ShardingSphereDriver
url: jdbc:shardingsphere:classpath:config.yaml
name: EncryptHikariCP
hikari:
minimumIdle: 10
maximumPoolSize: 200
autoCommit: true
idleTimeout: 30000
poolName: BaseHikariCP
maxLifetime: 1800000
connectionTimeout: 30000
connectionTestQuery: SELECT 1

如上配置后連接池才正常。

  • 輔助查詢列

輔助查詢列會根據你的配置是否使用輔助列,當沒有配置輔助查詢列時,執(zhí)行SQL如下:

圖片


使用的是加密列進行查詢了

當配置了輔助查詢列后:

圖片


使用的是輔助列查詢。

責任編輯:武曉燕 來源: 實戰(zhàn)案例錦集
相關推薦

2025-03-26 08:43:17

2022-11-18 18:36:24

2022-01-26 07:25:09

PythonRSA加解密

2024-07-17 08:29:20

2022-04-28 07:31:41

Springkafka數據量

2013-11-15 13:06:52

透明加解密hook技術數據安全

2022-07-27 08:49:34

接口加密解密

2011-08-01 14:36:06

加密RSA

2025-02-14 09:07:35

2022-05-30 07:31:38

SpringBoot搜索技巧

2024-12-24 08:44:55

ActiveMQRabbitMQ交換機

2017-12-07 10:25:55

LinuxGPG加密解密

2024-09-27 15:24:15

Spring數據加解密

2022-11-08 15:14:17

MyBatis插件

2022-12-14 09:06:58

接口Spring解密

2020-04-23 15:08:41

SpringBootMyCatJava

2021-11-10 11:40:42

數據加解密算法

2023-10-09 07:37:01

2025-03-19 08:36:55

2021-02-28 10:11:31

HelloWorldSSMSpringboot
點贊
收藏

51CTO技術棧公眾號