SSL协议相关知识简介.pdf
《SSL协议相关知识简介.pdf》由会员分享,可在线阅读,更多相关《SSL协议相关知识简介.pdf(5页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、 SSL 协议相关知识简介 引言 SSL 是一种在客户端与服务器端之间建立安全通道的协议。SSL 一经提出,就在 Internet 上得到广泛的应用。SSL 最常用来保护 Web 的安全。为了保护存有敏感信息 Web 的服务器的安全,消除用户在 Internet 上数据传输的安全顾虑。OpenSSL 是一个支持 SSL 认证的服务器它是一个源码开放的自由软件,支持多种操作系统。OpenSSL 软件的目的是实现一个完整的、健壮的、商业级的开放源码工具,通过强大的加密算法来实现建立在传输层之上的安全性。OpenSSL 包含一套 SSL协议的完整接口,应用程序应用它们能够很方便的建立起安全套接层,继
2、而能够通过网络进行安全的数据传输。2 SSL 协议概述 SSL 以对称密码技术与公开密码技术相结合,能够实现如下三个通信目标:(1)秘密性:SSL 客户机与服务器之间传送的数据都通过了加密处理,网络中的非法窃听者所获取的信息都将是无意义的密文信息。(2)完整性:SSL 利用密码算法与散列(HASH)函数,通过对传输信息特征值的提取来保证信息的完整性,确保要传输 的信息全部到达目的地,能够避免服务器与客户机之间的信息受到破坏。(3)认证性:利用证书技术与可信的第三方认证,能够让客户机与服务器相互识别对方的身份。为了验证证书持有者是其合法用户(而不是冒名用户),SSL 要求证书持有者在握手时相互交
3、换数字证书,通过验证来保证对方身份的合法性。3 SSL 协议的体系结构 SSL 协议位于 TCP/IP 协议模型的网络层与应用层之间,使用 TCP 来提供一种可靠的端到端的安全服务,它是客户/服务器应用之间的通信不被攻击窃听,同时始终对服务器进行认证,还能够选择对客户进行认证。SSL 协议在应用层通信之前就已经完成加密算法、通信密钥的协商与服务器认证工作,在此之后,应用层协议所传送的数据都被加密。SSL 实际上是共同工作的两层协议构成,如图 1 所示。从体系结构图能够看出 SSL 安全协议实际是 SSL 握手协议、SSL 修改密文协议、SSL 警告协议与 SSL记录协议构成的一个协议族。握手
4、协议 修改密 文协议 报警 协议 SSL 记录协议 TCP IP 图 1 SSL 体系结构 SSL 记录协议为 SSL 连接提供了两种服务:一是机密性,二是消息完整性。为了实现这两种服务,SSL 记录协议对接收的数据与被接收的数据工作过程是如何实现的呢?SSL 记录协议接收传输的应用报文,将数据分片成可管理的块,进行数据压缩(可选),应用 MAC,接着利用 IDEA、DES、3DES 或者其他加密算法进行数据加密,最后增加由内容类型、要紧版本、次要版本与压缩长度构成的首部。被接收的数据刚好与接收数据工作过程相反,依次被解密、验证、解压缩与重新装配,然后交给更高级用户。SSL 修改密文协议是使用
5、 SSL 记录协议服务的 SSL 高层协议的 3 个特定协议之一,也是其中最简单的一个。协议由单个消息构成,该消息只包含一个值为 1 的单个字节。该消息的唯一作用就是使未决状态拷贝为当前状态,更新用于当前连接的密码组。为了保障 SSL 传输过程的安全性,双方应该每隔一段时间改变加密规范。SSL 告警协议是用来为对等实体传递 SSL 的有关警告。假如在通信过程中某一方发现任何特殊,就需要给对方发送一条警示消息通告。警示消息有两种:一种是 Fatal 错误,如传递数据过程中,发现错误的 MAC,双方就需要立即中断会话,同时消除自己缓冲区相应的会话记录;第二种是 Warning 消息,这种情况,通信
6、双方通常都只是记录日志,而对通信过程不造成任何影响。SSL 握手协议能够使得服务器与客户能够相互鉴别对方,协商具体的加密算法与 MAC 算法与保密密钥,用来保护在 SSL 记录中发送的数据。SSL 握手协议同意通信实体在交换应用数据之前协商密钥的算法、加密密钥与对客户端进行认证(可选)的协议,为下一步记录协议要使用的密钥信息进行协商,使客户端与服务器建立并保持安全通信的状态信息。SSL 握手协议是在任何应用程序数据传输之前使用的。SSL 握手协议包含四个阶段:第一个阶段建立安全能力;第二个阶段服务器鉴别与密钥交换;第三个阶段客户鉴别与密钥交换;第四个阶段完成握手协议。4 SSL 协议的实现 基
7、于 OpenSSL 的程序能够被分为两个部分:客户机与服务器,使用 SSL 协议使通信双方能够相互验证对方身份的真实性,同时能够保证数据的完整性与机密性。建立 SSL 通信的过程如图 2 所示。图 2 SSL 通信过程 SSL 通信模型使用标准的 C/S 结构,除了在 TCP 层上进行传输之外,与普通的网络通信协议没有太大的区别,基于 OpenSSL的程序都要遵循下列几个步骤:(1)OpenSSL 初始化 在使用 OpenSSL 之前,务必进行相应的协议初始化工作,这能够通过下面的函数实现:int SSL_library_int(void);(2)选择会话协议 在利用 OpenSSL 开始 S
8、SL 会话之前,需要为客户端与服务器制定本次会话使用的协议,目前能够使用的协议包含 TLSv1.0、SSLv2、SSLv3、SSLv2/v3。需要注意的是,客户端与服务器务必使用相互兼容的协议,否则 SSL 会话将无法正常进行。(3)创建会话环境 在 OpenSSL 中创建的 SSL 会话环境称之 CTX,使用不一致的协议会话,其环境也 不一样的。申请 SSL 会话环境的 OpenSSL 函数是:SSL_CTX*SSL_CTX_new(SSL_METHOD*method);当 SSL 会话环境申请成功后,还要根据实际的需要设置 CTX 的属性,通常的设置是指定 SSL 握手阶段证书的验证方式与
9、加载自己的证书。制定证书验证方式的函数是:int SSL_CTX_set_verify(SSL_CTX*ctx,int mode,int(*verify_callback),int(X509_STORE_CTX*);为 SSL 会话环境加载 CA 证书的函数是:SSL_CTX_load_verify_location(SSL_CTX*ctx,const char*Ca char*Capath);为 SSL 会话加载用户证书的函数是:SSL_CTX_use_certificate_*ctx,const char*type);为 SSL 会话加载用户私钥的函数是:SSL_CTX_use_Priva
10、teKey_*ctx,const char*type);在将证书与私钥加载到 SSL 会话环境之后,就能够调用下面的函数来验证私钥与证书是否相符:int SSL_CTX_check_private_key(SSL_CTX*ctx);(4)建立 SSL 套接字 SSL 套接字是建立在普通的 TCP 套接字基础之上,在建立 SSL 套接字时能够使用下面的一些函数:SSL*SSl_new(SSL_CTX*ctx);/申请一个 SSL 套接字 int SSL_set_fd(SSL*ssl,int fd);)/绑定读写套接字 int SSL_set_rfd(SSL*ssl,int fd);/绑定只读套接
11、字 int SSL_set_wfd(SSL*ssl,int fd);/绑定只写套接字(5)完成 SSL 握手 在成功创建 SSL 套接字后,客户端应使用函数 SSL_connect()替代传统的函数 connect()来完成握手过程:int SSL_connect(SSL*ssl);而对服务器来讲,则应使用函数 SSL_ accept()替代传统的函数 accept()来完成握手过程:int SSL_accept(SSL*ssl);握手过程完成之后,通常需要询问通信双方的证书信息,以便进行相应的验证,这能够借助于下面的函数来实现:X509*SSL_get_peer_certificate(SS
12、L*ssl);该函数能够从 SSL 套接字中提取对方的证书信息,这些信息已经被 SSL 验证过了。X509_NAME*X509_get_subject_name(X509*a);该函数得到证书所用者的名字。(6)进行数据传输 当 SSL 握手完成之后,就能够进行安全的数据传输了,在数据传输阶段,需要使用 SSL_read()与 SSL_write()来替代传统的 read()与 write()函数,来完成对套接字的读写操作:int SSL_read(SSL*ssl,void*buf,int num);int SSL_write(SSL*ssl,const void*buf,int num);(
13、7)结束 SSL 通信 当客户端与服务器之间的数据通信完成之后,调用下面的函数来释放已经申请的 SSL 资源:int SSL_shutdown(SSL*ssl);/关闭 SSL 套接字 void SSl_free(SSL*ssl);/释放 SSL 套接字 void SSL_CTX_free(SSL_CTX*ctx);/释放 SSL 会话环境 4 结束语 SSL 协议使用数字证书进行双端实体认证,用非对称加密算法进行密钥协商,用对称加密算法将数据加密后进行传输以保证数据的保密性,同时通过计算数字摘要来验证数据在传输过程中是否被篡改与伪造,从而为敏感数据在 Internet 上的传输提供了一种安全
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- SSL 协议 相关 知识 简介
限制150内