我有一个使用 SQL Server 2008 数据库的 Windows 应用程序。
我不想让用户看到数据库表。
我该如何对我的数据库中的表进行加密?
我有一个使用 SQL Server 2008 数据库的 Windows 应用程序。
我不想让用户看到数据库表。
我该如何对我的数据库中的表进行加密?
您有不同的选择。
您可以为数据使用对称加密:
CREATE TABLE sales ( ... )
创建对称密钥:
CREATE CERTIFICATE cert_sales WITH SUBJECT = N'Sales certificate',
START_DATE = N'2009-01-01', EXPIRY_DATE = N'2018-12-31';
CREATE SYMMETRIC KEY symkey_sales WITH ALGORITHM = AES_256
ENCRYPTION BY CERTIFICATE cert_sales
加密数据:
TRUNCATE TABLE sales;
OPEN SYMMETRIC KEY symkey_sales DECRYPTION BY CERTIFICATE cert_sales;
INSERT INTO sales() SELECT a, ENCRYPTBYKEY(Key_Guid(N'symkey_sales'), B) FROM T2;
CLOSE SYMMETRIC KEY symkey_sales;
OPEN SYMMETRIC KEY symkey_sales DECRYPTION BY CERTIFICATE cert_sales;
SELECT a, CAST(DecryptByKey(B) as nvarchar(100)) FROM sales;
CLOSE SYMMETRIC KEY symkey_sales;
创建主密钥:
USE master
go
CREATE MASTER KEY ENCRYPTION BY PASSWORD = 'My$Strong$Password$123'
CREATE CERTIFICATE DEK_EncCert WITH SUBJECT = 'DEK Encryption Certificate'
USE MySecretDB
go
CREATE DATABASE ENCRYPTION KEY WITH ALGORITHM = AES_256
ENCRYPTION BY SERVER CERTIFICATE DEK_EncCert
打开加密:
ALTER DATABASE MySecretDB SET ENCRYPTION ON
加密无法解决问题 - SQL Server级别的加密只是加密了文件,一旦登录,数据就是可见的。
唯一正确的解决方案被称为“编程”。基本上采用客户端/服务器模式,不让用户直接连接数据库。
或者你可以在表格上使用权限+应用程序密码来提升应用程序(而不是用户)的权限,但这也是不安全的(因为你必须把密码放在某个地方)。