准备SQL Server 2008透明数据加密

作者:戴羽 来源:IT专家网 时间:2009-01-22 14:18:00 

问题

当浏览SQL Server 2008的新特性时,我们看到了透明数据加密。这看起来很有趣。您能为我们解释一下并介绍下执行它的细节吗?

专家解答

TDE(透明数据加密)是SQL Server 2008中的一个新特性;它提供了对数据和日志文件的实时加密。数据在它写到磁盘之前进行加密;当它从磁盘读出来时进行解密。TDE的“透明”是指加密是由数据库引擎来执行的,而SQL Server客户端对此完全不知道。要进行加密和解密不必编写任何代码。只要执行两个步骤将数据库为TDE准备好,然后加密就通过一个ALTER DATBASE命令在数据库级别开启了。

我们可能都听过关于保存了敏感信息的备份磁带丢失或被窃的事件。有了TDE,只要这个数据库开启了加密,那么只要使用标准BACKUP命令就会将备份文件也加密了。如果没有对用来加密数据的密钥的访问权限,那么备份文件(或磁盘上)中的数据就完全没用。

在我们进入执行TDE的步骤之前,让我们花几分钟来大概地讨论下加密。Wikipedia对加密的定义是“使用一个算法(叫做密码)来转化数据(指明码文本)、使其除非具有特定知识,一般指密钥,不然任何人都不能读取的过程”。为了加密数据,我选择了一个有效的算法并提供了密钥。加密所提供的安全性是基于算法的强度和密钥的保护。密钥有两种——对称密钥和非对称密钥。对于对称密钥,对数据的加密和解密使用相同的值。非对称密钥有两个组成部分——一个私钥和一个公钥。我使用私钥来加密数据而其他人必须使用公钥来解密数据。总之,对称密钥或非对称密钥对的私钥必须安全地存储以便可以有效地加密。

现在让我们看一个关于怎样执行TDE的例子。对一个特定数据库执行TDE包括下面四个步骤:

创建一个主钥。

创建或获得一个受主钥保护的证书。

创建数据库加密密钥并使用证书保护它。

将数据库设为使用加密。

创建一个主钥

主钥是一个对称密钥,是用来创建证书和非对称密钥的。执行下面的脚本来创建一个主钥: 

      USE master;
     
  CREATE MASTER KEY

  ENCRYPTION BY PASSWORD = 'Pass@word1';

  GO

注意,密码应该为强密码(例如使用字母、数字、大写、小写和特殊字符),而且你应该将它备份(使用BACKUP MASTER KEY)和保存在一个安全地方。.

创建证书

证书可以用来创建用于数据加密的对称密钥或用来直接加密数据。执行下面的脚本来创建一个证书: 

      USE master;
     
  CREATE CERTIFICATE TDECert

  WITH SUBJECT = 'TDE Certificate'

  GO

标签:
0
投稿

猜你喜欢

  • 我要如何了解用户的需求

    2007-08-26 17:19:00
  • 网页用多宽才更合适?

    2009-04-07 14:07:00
  • 全透视:CSS Z-index 属性

    2009-09-21 12:52:00
  • javascript双击自动滚屏单击停止

    2008-10-13 13:05:00
  • ORACLE11g随RHEL5系统自动启动与关闭的设置方法

    2009-08-31 12:43:00
  • 也谈谈DIV+CSS的牛角尖

    2007-11-16 16:12:00
  • 如何固定表格的标题行和标题列

    2007-09-20 13:03:00
  • Flash对象在(x)HTML中的格式和参数及安全性

    2010-04-01 11:55:00
  • Check In和Check Out的多人协作管理

    2007-02-03 11:39:00
  • PHP抽象工厂模式Abstract Factory Pattern优点与实现方式

    2023-05-25 03:04:57
  • on error goto (Vbscript)和try catch

    2008-08-04 13:22:00
  • 丰富段落里的标签

    2008-03-16 14:11:00
  • WEB2.0网页制作标准教程(3)定义语言编码

    2007-11-13 13:23:00
  • ASP中的全角和半角之间的转化

    2008-06-06 13:34:00
  • 解析ASP与SQL server互操作的时间处理

    2008-05-17 11:57:00
  • [译]2009年海外Web设计风潮(上)

    2009-01-23 09:21:00
  • javascript闭包的秘密

    2008-09-28 20:39:00
  • AJAX在GET中文的时候解决乱码的方法

    2007-11-04 13:04:00
  • ORACLE数据库查看执行计划的方法

    2012-06-06 20:15:52
  • VBScript中变量作用域

    2007-11-02 10:03:00
  • asp之家 网络编程 m.aspxhome.com