惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

宝玉的分享
宝玉的分享
NISL@THU
NISL@THU
E
Exploit-DB.com RSS Feed
L
LINUX DO - 热门话题
L
Lohrmann on Cybersecurity
K
Kaspersky official blog
Project Zero
Project Zero
Cisco Talos Blog
Cisco Talos Blog
T
The Exploit Database - CXSecurity.com
P
Palo Alto Networks Blog
C
CXSECURITY Database RSS Feed - CXSecurity.com
T
Threatpost
S
Schneier on Security
G
GRAHAM CLULEY
The Hacker News
The Hacker News
T
Threat Research - Cisco Blogs
Scott Helme
Scott Helme
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
P
Privacy & Cybersecurity Law Blog
C
Cyber Attacks, Cyber Crime and Cyber Security
Cyberwarzone
Cyberwarzone
C
CERT Recently Published Vulnerability Notes
T
Tor Project blog
AWS News Blog
AWS News Blog
Simon Willison's Weblog
Simon Willison's Weblog
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
爱范儿
爱范儿
P
Privacy International News Feed
云风的 BLOG
云风的 BLOG
P
Proofpoint News Feed
S
Securelist
G
Google Developers Blog
The Last Watchdog
The Last Watchdog
Google Online Security Blog
Google Online Security Blog
美团技术团队
F
Fortinet All Blogs
小众软件
小众软件
Recorded Future
Recorded Future
V
Visual Studio Blog
B
Blog RSS Feed
H
Help Net Security
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
Google DeepMind News
Google DeepMind News
Blog — PlanetScale
Blog — PlanetScale
博客园 - 聂微东
Stack Overflow Blog
Stack Overflow Blog
Martin Fowler
Martin Fowler
Latest news
Latest news
Spread Privacy
Spread Privacy
H
Heimdal Security Blog

博客园 - 董晓涛

如何将存储过程执行后的结果集放入临时表 Detect SQL timeout from ASP & Issue RollbackTrans 如何解决:Error 14274: 无法添加、更新或删除从MSX服务器上发起的作业. Useful Links(to Learn SQL Server) Encrypting Data With the SQL Server Encrypt Function Convert IP To Numberic Generate table structure Generate Time Dim Generate Insert data script on a table. - 董晓涛 Execute T-SQL asynchronously Don't Use Select * Sql Server数据库被置疑后解决方法 SQL Server 2005中对BLOB的支持(ntext,text and image) SQL Server 2000 Service Pack 4 is released 数据规范化 Microsoft SQL Server 2005 and Vs.net 2005 April 2005 Version XML IN 20 MINUTES! CLR Integrated in SQL Server 2005 XQuery in SQL Server 2005
SQL Server 2005 symmetric encrytion sample
董晓涛 · 2005-07-29 · via 博客园 - 董晓涛

DROP DATABASE DEMO;
GO

CREATE DATABASE DEMO;
GO

USE DEMO;
GO

--the database master key is always encrypted (using triple_DES) with user-supplier password
--stored in the sys.symmetric_keys; and at the same time using service master key to encrypt
--the database master key and stored in sys.databases table
CREATE MASTER KEY
ENCRYPTION BY PASSWORD='23987hxJKL95QYV4369#ghf0%94467GRdkjuw54ie5y01478dDkjdahflkujaslekjg5k3fd117r$$#1946kcj$n44ncjhdlj'
GO

CREATE TABLE  EMPLOYEE
(
EmployeeID INT PRIMARY KEY ,
FULLNAME VARCHAR(100),
SALARY INT,
ENCRYPTSALARY VARBINARY(4000)
)
 
USE MASTER;
GO
CREATE LOGIN DAVID01 WITH PASSWORD='DAVID01'
CREATE LOGIN DAVID02 WITH PASSWORD='DAVID02'

USE DEMO;
GO
CREATE USER DAVID01 FOR LOGIN DAVID01
GRANT SELECT,INSERT,UPDATE  ON EMPLOYEE TO DAVID01

CREATE USER DAVID02 FOR LOGIN DAVID02
GRANT SELECT,INSERT,UPDATE ON EMPLOYEE TO DAVID02

--EXECUTE AS LOGIN='DAVID01'
--SELECT * FROM EMPLOYEE
--
--REVERT
CREATE CERTIFICATE CER_SK_David01
AUTHORIZATION David01
WITH SUBJECT ='CERTIFICATE FOR ACCESS SYMMETRIC KEYS -FOR USE BY David01'


CREATE CERTIFICATE CER_SK_David02
AUTHORIZATION David02
WITH SUBJECT ='CERTIFICATE FOR ACCESS SYMMETRIC KEYS -FOR USE BY David02'


CREATE SYMMETRIC KEY SK_EMPLOYEES_David01
AUTHORIZATION David01
WITH ALGORITHM=AES_192
ENCRYPTION BY CERTIFICATE CER_SK_David01

CREATE SYMMETRIC KEY SK_EMPLOYEES_David02
AUTHORIZATION David02
WITH ALGORITHM=AES_192
ENCRYPTION BY CERTIFICATE CER_SK_David02

SELECT * FROM SYS.OPENKEYS
--
--ALTER SYMMETRIC KEY SK_EMPLOYEES
--ADD ENCRYPTION BY CERTIFICATE CERT_SK_DAVID

SELECT *--  C.NAME
FROM SYS.KEY_ENCRYPTIONS KE,SYS.CERTIFICATES C,SYS.SYMMETRIC_KEYS SK
WHERE KE.THUMBPRINT=C.THUMBPRINT AND SK.NAME='SK_EMPLOYEES_David01' AND KE.KEY_ID=SK.SYMMETRIC_KEY_ID

exec as login='David01'


OPEN SYMMETRIC KEY SK_EMPLOYEES_DAVID01 DECRYPTION BY CERTIFICATE CER_SK_DAVID01

INSERT INTO EMPLOYEE
VALUES(1,'DAVIDDONG','10000',ENCRYPTBYKEY(KEY_GUID('SK_EMPLOYEES_David01'),'10000'));


INSERT INTO EMPLOYEE
VALUES(2,'DAVIDDONG','12000',ENCRYPTBYKEY(KEY_GUID('SK_EMPLOYEES_David01'),'12000'));

INSERT INTO EMPLOYEE
VALUES(3,'DAVIDDONG','15000',ENCRYPTBYKEY(KEY_GUID('SK_EMPLOYEES_David01'),'15000'));

SELECT EMPLOYEEID,SALARY,CONVERT(VARCHAR(1000),DECRYPTBYKEY(ENCRYPTSALARY)) AS SALARY1  FROM EMPLOYEE

CLOSE ALL SYMMETRIC KEYS

REVERT

SELECT EMPLOYEEID,SALARY,CONVERT(VARCHAR(1000),DECRYPTBYKEY(ENCRYPTSALARY)) AS SALARY1  FROM EMPLOYEE

EXECUTE AS LOGIN='DAVID02'

OPEN SYMMETRIC KEY SK_EMPLOYEES_DAVID02 DECRYPTION BY CERTIFICATE CER_SK_DAVID02

-----
INSERT INTO EMPLOYEE
VALUES(4,'DAVIDDONG','10000',ENCRYPTBYKEY(KEY_GUID('SK_EMPLOYEES_David02'),'10000'));


INSERT INTO EMPLOYEE
VALUES(5,'DAVIDDONG','12000',ENCRYPTBYKEY(KEY_GUID('SK_EMPLOYEES_David02'),'12000'));

INSERT INTO EMPLOYEE
VALUES(6,'DAVIDDONG','15000',ENCRYPTBYKEY(KEY_GUID('SK_EMPLOYEES_David02'),'15000'));

SELECT EMPLOYEEID,SALARY,CONVERT(VARCHAR(1000),DECRYPTBYKEY(ENCRYPTSALARY)) AS SALARY1  FROM EMPLOYEE

CLOSE ALL SYMMETRIC KEYS

REVERT

SELECT EMPLOYEEID,SALARY,CONVERT(VARCHAR(1000),DECRYPTBYKEY(ENCRYPTSALARY)) AS SALARY1  FROM EMPLOYEE