当前位置: 首页 > news >正文

如何对数据库的表字段加密解密处理?

对于表格数据的加密处理,通常涉及到对数据库中存储的数据进行加密,以保护敏感信息。
在这里插入图片描述

Java示例(使用AES算法加密数据库表数据)

首先,你需要一个数据库连接,这里假设你使用的是JDBC连接MySQL数据库。以下是一个简化的示例,展示如何对数据库中的一条记录进行加密和解密。

import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import java.sql.*;public class DatabaseEncryption {public static void main(String[] args) {String url = "jdbc:mysql://localhost:3306/yourdatabase";String user = "yourusername";String password = "yourpassword";// 生成密钥KeyGenerator keyGenerator = KeyGenerator.getInstance("AES");keyGenerator.init(128); // 可以选择128, 192, 256位SecretKey secretKey = keyGenerator.generateKey();byte[] keyBytes = secretKey.getEncoded();// 连接数据库try (Connection conn = DriverManager.getConnection(url, user, password)) {// 加密数据String dataToEncrypt = "Sensitive Data";Cipher cipher = Cipher.getInstance("AES");cipher.init(Cipher.ENCRYPT_MODE, new SecretKeySpec(keyBytes, "AES"));byte[] encryptedData = cipher.doFinal(dataToEncrypt.getBytes());// 将加密数据插入数据库String insertQuery = "INSERT INTO mytable (dcol) VALUES (?)";try (PreparedStatement pstmt = conn.prepareStatement(insertQuery)) {pstmt.setBytes(1, encryptedData);pstmt.executeUpdate();}// 从数据库读取加密数据String selectQuery = "SELECT dcol FROM mytable WHERE id = ?";try (PreparedStatement pstmt = conn.prepareStatement(selectQuery)) {pstmt.setInt(1, 1); // 假设你要查询的记录ID为1try (ResultSet rs = pstmt.executeQuery()) {if (rs.next()) {byte[] encryptedDataFromDb = rs.getBytes("dcol");// 解密数据cipher.init(Cipher.DECRYPT_MODE, new SecretKeySpec(keyBytes, "AES"));byte[] decryptedData = cipher.doFinal(encryptedDataFromDb);System.out.println("Decrypted Data: " + new String(decryptedData));}}}} catch (SQLException e) {e.printStackTrace();}}
}

在这里插入图片描述

C#示例(使用AES算法加密数据库表数据)

这个示例假设你使用的是Entity Framework Core来操作数据库,这里以SQL Server为例。

using System;
using System.Data.SqlClient;
using System.Security.Cryptography;
using System.Text;public class DatabaseEncryption
{public static void Main(){string connectionString = "Server=your_server;Database=your_database;User Id=your_user;Password=your_password;";// 生成密钥using (Aes aesAlg = Aes.Create()){aesAlg.GenerateKey();byte[] key = aesAlg.Key;// 加密数据string dataToEncrypt = "Sensitive Data";byte[] encryptedData = EncryptStringToBytes_Aes(dataToEncrypt, key);// 将加密数据插入数据库using (SqlConnection conn = new SqlConnection(connectionString)){conn.Open();using (SqlCommand cmd = new SqlCommand("INSERT INTO mytable (dcol) VALUES (@data)", conn)){cmd.Parameters.AddWithValue("@data", encryptedData);cmd.ExecuteNonQuery();}}// 从数据库读取加密数据using (SqlConnection conn = new SqlConnection(connectionString)){conn.Open();using (SqlCommand cmd = new SqlCommand("SELECT dcol FROM mytable WHERE id = @id", conn)){cmd.Parameters.AddWithValue("@id", 1); // 假设你要查询的记录ID为1byte[] encryptedDataFromDb = (byte[])cmd.ExecuteScalar();// 解密数据string decryptedData = DecryptStringFromBytes_Aes(encryptedDataFromDb, key);Console.WriteLine("Decrypted Data: " + decryptedData);}}}}// EncryptStringToBytes_Aes 和 DecryptStringFromBytes_Aes 方法与之前提供的C#示例相同
}

在这里插入图片描述

在实际应用中,你需要根据你的数据库类型(如MySQL、PostgreSQL等)和ORM框架(如Hibernate、Entity Framework等)调整数据库连接和操作代码。同时,密钥管理是一个重要的安全问题,你需要确保密钥的安全存储和传输,避免将密钥硬编码在代码中。

http://www.lryc.cn/news/477115.html

相关文章:

  • 六、Go语言快速入门之数组和切片
  • Java:数组的定义和使用(万字解析)
  • 密码学简要介绍
  • 2024.11月最新智能问答AI创作系统源码,GPT4.0多模态模型+AI换脸+AI智能体GPTs应用+AI绘画(Midjourney)+详细搭建部署教程
  • 江协科技STM32学习- P34 I2C通信外设
  • Python 继承、多态、封装、抽象
  • 在.net下后台设置前台UEditor编辑器不可编辑
  • Flutter CustomScrollView 效果-顶栏透明与标签栏吸顶
  • 【新手入门软件测试--该如何分辨前后端问题及如何定位日志--前后端问题分辨与日志定位查询问题】
  • 【Java Web】DAO模式及单例模式(含代码示例)
  • 深入探讨SEO分析技巧助力网站流量提升
  • Chrome 130 版本开发者工具(DevTools)更新内容
  • 深度学习基础知识-残差网络ResNet
  • Linux云计算个人学习总结(二)
  • Java入门(7)--网络编程
  • [思考记录]思维局限,以为懂了
  • 力扣题目解析--最长公共前缀
  • 不画饼——研究生学习和赚钱的平衡点
  • 华为实时视频使用FLV播放RTSP流
  • JAVA设计模式之【建造者模式】
  • 【jvm】为什么Xms和Xmx的值通常设置为相同的?
  • windows查看net网络监听端口命令和工具(ipconfig、netstat、tasklist、TCPView)
  • JAVA-数据结构- 二叉搜索树
  • 深入研究 RAG 流程中的关键组件
  • 新手如何学习python并快速成为高手
  • Linux历史命令history增加执行时间显示
  • 从 vue 源码看问题 — 你知道 Hook Event 吗?
  • 信息安全工程师(68)可信计算技术与应用
  • 每日OJ题_牛客_相差不超过k的最多数_滑动窗口_C++_Java
  • 来咯来咯webSocket