HTTPS 服务器和客户端如何进行加密解密的?

这里写图片描述

HTTPS = HTTP + SSL / TLS.
普通的http请求+数据加密模块.
那么,如何进行数据加密的呢?

  1. 客户端发起HTTPS请求
    客户端输入一个https网址,然后连接到server的443端口。

  2. 服务端的配置
    采用HTTPS协议的服务器必须要有一套数字证书-,( 公钥public key & 私钥private key),可以自己制作,也可以向组织申请。
    区别:自己颁发的证书需要客户端验证通过,才可以继续访问;而使用受信任的公司申请的证书则不会弹出提示页面。

  3. 传送证书
    这个证书其实就是公钥,只是包含了很多信息,如证书的颁发机构,过期时间等等。

  4. 客户端解析证书
    两步验证 - 客户端的TLS来完成的.
    第一步:验证公钥是否有效,比如颁发机构,过期时间等等,如果发现异常,则会弹出一个警告框,提示证书存在问题。
    第二步:如果证书没有问题,那么就生成一个随即值(双方共有的私钥)。然后用证书对该随机值进行加密。

  5. 传送加密信息
    这部分传送的是用证书加密后的随机值,目的就是让服务端得到这个随机值,以后客户端和服务端的通信就可以通过这个随机值来进行加密解密了。

  6. 服务段解密信息
    服务端用私钥解密后,得到了客户端传过来的随机值,然后把内容通过该值进行对称加密。

  7. 传输加密后的信息
    这部分信息是服务段用私钥加密后的信息,可以在客户端被还原(解密)

  8. 客户端解密信息
    客户端用之前生成的私钥解密服务段传过来的信息,于是获取了解密后的内容。整个过程中间人即使监听到了数据,也束手无策。

–EOF–

原博客: http://blog.csdn.net/sean_cd/article/details/6966130

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
客户端服务器之间的加密解密可以使用SSL(Secure Sockets Layer)协议来实现。SSL是一种加密通信协议,它使用公钥加密和私钥解密的方式来保护数据传输的安全。 Python标准库中提供了ssl模块,可以使用该模块来实现SSL加密解密。下面是一个简单的示例代码: 服务端代码: ```python import socket import ssl def main(): # 创建socket对象 server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 绑定IP地址和端口号 server_address = ('localhost', 8000) server_socket.bind(server_address) # 开始监听 server_socket.listen(1) # 等待客户端连接 print('等待客户端连接...') client_socket, client_address = server_socket.accept() # 使用ssl包装socket对象 ssl_socket = ssl.wrap_socket(client_socket, server_side=True, certfile='server.crt', keyfile='server.key') # 接收客户端数据 data = ssl_socket.recv(1024) print('接收到客户端数据:', data.decode()) # 发送数据给客户端 message = 'Hello, client!' ssl_socket.send(message.encode()) # 关闭连接 ssl_socket.close() server_socket.close() if __name__ == '__main__': main() ``` 客户端代码: ```python import socket import ssl def main(): # 创建socket对象 client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 连接服务器 server_address = ('localhost', 8000) client_socket.connect(server_address) # 使用ssl包装socket对象 ssl_socket = ssl.wrap_socket(client_socket, ca_certs='server.crt') # 发送数据给服务器 message = 'Hello, server!' ssl_socket.send(message.encode()) # 接收服务器数据 data = ssl_socket.recv(1024) print('接收到服务器数据:', data.decode()) # 关闭连接 ssl_socket.close() if __name__ == '__main__': main() ``` 在上述代码中,服务端使用`ssl.wrap_socket()`方法将原始的socket对象包装成ssl socket,同时指定了服务器证书和私钥的位置。客户端也使用`ssl.wrap_socket()`方法将原始的socket对象包装成ssl socket,并指定了服务器证书的位置。这样客户端服务器之间的通信就可以通过SSL协议进行加密解密了。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值