在这一专题中我们将按OSI分层角度探讨网络安全。我们将深入研究OSI堆栈,从物理层开始直到应用层。从分析每一层的漏洞出发,假想攻击这些漏洞的各种可能性,在此基础上讨论各个网络层次的安全防御手段。在讨论了所有的技术环节之后,并没有忘记“人”对于网络安全因素的影响,因此在OSI七层模型的基础上扩展了“人工层”。
OSI模式的第6层是表示层。表示层是OSI模型唯一负责信息表现的。它是作为一个数据转换器使用的,它将数据从一个格式转换到另一个格式。如果你知道这些格式,如ASCII、EBCDIC 或JPEG,那么就对了;但是,同时表达层还可以用于加密。其中一个例子就是安全套接字层(Secure Sockets Layer,SSL)。这个协议是一个加密解决方案,它保护传输中的数据的安全。SSL是位于传输层之上,应用层之下的。由于SSL在数据安全方面扮演了很重要的角色,所以本章将对其进行重点阐述。
我们先了解一些背景知识。Netscape在1994开发了SSL并将其作为一种网络通讯安全方法。其中,SSL是专门用于保护Web浏览器和Web服务器之间的数据安全的。SSL为应用提供安全的电子商务手段。但是,SSL并不是一个工业标准——它是Netscape所开发的——而传输层安全(Transport Layer Security,TLS)才是。TLS是由因特网工程推动小组(Internet Engineering Task Force,IETF)开发的。目前TLS的版本是1.1,它在RFC4346中描述。使用TLS的程序跟使用SSL的程序运行非常相似。大体上,SSL和TLS是可以互通的。这两个服务都使用一个标准的握手过程来建立通信:
1. 用户使用一个Web 浏览器来连接一个有安全URL的Web服务器。
2. Web服务器响应客户端的请求并向将服务器的数字证书发送到Web浏览器上。其中X.509是最常用的证书类型。
3. 然后客户端验证该证书是有效的和正确的。证书是有知名的权威机构发布的,如Thawte 和Verisign。这一步很重要,因为证书证明了Web服务器所在组织是合法的。
4. 一旦证书被确认有效,客户端便生成一个一次性的会话密钥,它将用于加密与Web服务器的所有通信。
5. 然后客户端用Web服务器的公共密钥加密会话密钥,并将它与数字证书一起传输。使用Web 服务器的会话密钥确保了只有Web服务器才可以解密数据。
6. 此时,一个安全的会话就建立了,并且双方可以通过安全的通道进行通讯。
这个握手程序允许双方进行可信的通信。事实上,客户端和Web服务器仍旧像往常一样使用TCP来回传输数据,其中不同的是传输的数据流是加密的。另外也有一些控制被包含进来,以保证信息的完整性。这样就保证了双方的互信,以及在传输中信息并没有被改变。
表示层威胁
虽然SSL和TLS有着很高的可信度,但是威胁还是存在的。其中有两种最可能的威胁,它们是:伪证书攻击和中间人攻击。伪证书攻击指的是攻击者向客户端提供一个假证书。客户端应该会注意到这种攻击——他们将收到一个关于证书问题的弹出对话窗口警告。这个证书会跟真实证书非常相似,但它不是由可信任认证机构所颁发的。中间人攻击难度比较大,因为攻击者必须拦截客户端和服务器之间的通信。然后,攻击者再用自己的密钥取代合法的密钥。
虽然这些针对SSL的攻击都是可能的,但是更大的威胁是那些完全不使用任何加密手段的业务单位,它们只是简单地用明文传输他们的客户信息。诸如SSL和TLS等协议已经考虑所有可能的威胁,并也已经被证明它们足够保证信息安全。这是由每天进行的成千上百万的安全数据交换所证明的。如果这里的SSL探讨引起了你学习更多关于这种技术的兴趣,你可以继续研究一下Stunnel。Stunnel是用于加密内部SSL的任意TCP连接的。
(责任编辑:)