SSL握手过程是HTTPS协议中的一个核心部分,它允许客户端及服务器之间进行身份验证,并确保在数据传输的过程中双方的数据都得到了加密保护。在HTTPS连接成功建立之前,SSL握手过程必须在客户端及服务器之间完成。SSL握手过程是整个HTTPS传输过程的安全基石,确保了传输过程中双方的数据即便被黑客窃取也是加密的。
SSL(Secure Socket Layer)是为了解决互联网应用的保密、完整性、验证等问题而设计的安全协议。对于HTTPS协议来说,它是在HTTP协议的基础上加上一层SSL/TLS协议,确保荷载信息在传输过程中得到安全的保护,防止被中间人窃取、伪造、篡改或者重放攻击和其他一些安全问题。
在HTTPS协议连接建立的过程中,SSL握手是不可或缺的一环。SSL握手可以认为是客户端与服务器之间进行的安全协商过程,也是整个传输过程的安全基石。SSL握手完成后,客户端和服务器之间就可以开始加密传输数据。
SSL握手的过程主要包括以下几个步骤:
1. 客户端发送ClientHello消息
客户端在建立HTTPS连接后,首先发送一个ClientHello消息,该消息包含以下信息:
- SSL/TLS协议版本。
- 支持的加密算法集合。
- 随机数(client_random)。
- 按顺序列表打算访问的服务器名。
2. 服务端响应ServerHello消息
服务器收到客户端的ClientHello消息后,根据客户端发来的协议版本信息和加密算法列表选定适合的这两项,然后发送一个ServerHello消息给客户端,该消息包含以下信息:
- 选定的协议版本。
- 选定的加密算法。
- 随机数(server_random)。
3. 服务端发送证书
服务端向客户端发送自己的数字证书,以供客户端验证确认服务器的身份。证书通常以X.509格式存储。客户端使用数字证书中的公钥,检验这个数字证书是否是可以信赖的。
如果运营商对SSL进行中间人劫持,将会伪造一个数字证书发给客户端,在这个数字证书中,证书公钥对应的所有者会是服务器名,这也是窃取机密信息或者篡改数据的原因之一。
4. 客户端验证证书
客户端收到服务端发送的证书后,按照一定的规则验证证书的合法性,如果验证通过,则开始进行下一步的交互。
5. 客户端发送ClientKeyExchange消息
客戶端发送了一个包括重定向信息、余下消息长度和随机数据的信息。它使用发给服务器的随机数和盐值生成预主密钥,并将加密后的预主密钥发送给服务器。
6. 客户端发送ChangeCipherSpec消息
客户端向服务器发送一个消息告诉服务器自己已经提前完成了所有准备工作,可以开始使用加密通信协定了。
7. 服务端发送ChangeCipherSpec消息
服务器向客户端发送一个消息告诉客户端自己已经也完成了所有准备工作,可以开始使用加密通信协定了。
8. 客户端发送Finished消息
客户端向服务器发送一个Finished消息,该消息包含了一个经过计算的验证数据,用于验证握手过程中是否存在任何修改或篡改。
9. 服务端发送Finished消息
服务端向客户端发送一个Finished消息,该消息包含了一个经过计算的验证数据,用于验证握手过程中是否存在任何修改或篡改。
当以上几步完成后,SSL握手过程就完成了。此时,客户端和服务器之间的连接是加密的,所有传输的数据都受到加密保护。
SSL握手过程是HTTPS协议的重要组成部分,可以认为是客户端与服务器之间的安全协商过程。在SSL握手完成后,客户端和服务器之间可以开始安全传输数据。因此,SSL握手过程对于保障HTTPS连接的安全性具有至关重要的作用,完整性,隐私性和可靠性。
互亿无线竭力为您提供全面的SSL证书解决方案,保障您网站的安全与信任。我们呈现丰富多样的SSL证书类型,如DV(域名验证)、OV(组织验证)和EV(扩展验证)证书,满足您各类安全需求。我们提供全面的证书类型,涵盖单域名、多域名以及通配符证书。以便适应您的网站架构需求。我们与全球证书品牌,如Globalsign、DigiCert、GeoTrust、vTrus、COMODO等建立了密切的合作关系,确保您获得高品质的SSL证书。
![]() |
一站式SSL证书购买方案 |
![]() |
享受快速签发的SSL证书服务 |
![]() |
我们提供高性价比的SSL证书价格方案 |
![]() |
提供全方位的SSL证书服务 |
本文主要用于介绍申请SSL证书时有关域名的注意事项。
(1)使用哪个域名申请
以demo.ihuyi.com网站为例,您在维护网站安全时通常会出现以下两种情况:
1、用户登录页面为http://demo.ihuyi.com/login.asp,此时,您需要申请SSL数字证书,以确保用户输入的用户名、密码的安全。
2、用户登录信息管理页面http:/demo.ihuyi.com/oa/manage.asp,您需要使用SSL数字证书,以确保内部管理系统的信息安全。
在上述两种情况下,需要使用demo.ihuyi.com申请SSL数字证书作为域名,从而实现相关页面的安全保护。
(2)如何优化网站安全
如果您的网站访问量较大,建议为使用SSL数字证书的网站页面配置独立的Web服务器,即HTTPServer。同时,使用独立域名申请SSL证书,例如,learn.ihuyi.com或guide.ihuyi.com。
(3)填写域名的一致性
在访问https://demo.ihuyi.com网站时,网站域名必须与申请SSL数字证书的域名一致,否则浏览器可能会出现“安全证书上的名称无效或与网站名称不匹配”的提示。
我们知道证书链的概念,所以,通过服务器返回网站证书路径,我们通过终端证书-中间证书-根证书逐步验证,如果在信任证书列表中找到根证书可以签署证书链上的证书,证书是信任的。这很容易实现,因为JavaJDK帮助我们实现了必要的验证逻辑,并且对客户端是透明的,使用默认的TrustManager:
SSLContextcontext=SSLContext.getInstance("TLS");
///Trustmanager传null将使用系统默认的“SunX509”TrustManager
context.init(null,null,null);
URLurl=newURL("https://www.baidu.com");
HttpsURLConnectionconnection=(HttpsURLConnection)url.openConnection();
connection.setSSLSocketFactory(context.getSocketFactory());
InputStreamis=connection.getInputStream();
当SSLContextinit方法的第二个参数传输到null时,Trustmanager将使用默认的Sunx509实现,代码如下:
TrustManagerFactorymgr=TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm())
mgr.init((KeyStore)null);
TrustManager[]var2=var4.getTrustMan·agers();
当然,功能也可以在TrustManager上扩展,但除非场景极其特殊,否则一般不建议做。上述验证方法在Android系统中基本相似。在启动REST接口访问时,可以根据场景使用不同的验证方法。那么,当网站嵌入网站时,如何保证访问的安全呢?以下是网站的一些方法:
当webview加载页面时,将对证书进行验证。当验证错误时,将回调该方法。Ssleror对象将传递证书。您可以在这里进行自定义验证。自定义验证逻辑可以对传入的证书进行任何自定义验证。同时,通过以上分析,可以看出,要求的安全取决于客户端和服务器之间的许多合同。同时,客户端对证书的验证是整个保证的基础。
v
SSL是网络加密传输协议,是支持在网络服务器(主机)和网页浏览器(客户端)之间建立加密连接的标准技术。网站安装SSL数字证书时,可以通过https访问网站,浏览器地址栏显示“锁的标识”,点击标识显示单位/个人认证信息。这个证书也是类似驾照、护照和营业执照的电子副本,因为它配置在服务器上,也叫SSL服务器证书。
150,000家
企业客户
21年
行业经验
2V1
2对1客户支持