在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
HTTPS就等于HTTP加上TLS(SSL),HTTPS协议的目标主要有三个: 数据保密性。保证内容在传输过程中不会被第三方查看到。就像快递员传递包裹时都进行了封装,别人无法知道里面装了什么东西。 启用HTTPS之前需要有证书,而证书需要首先在自己服务器上创建CSR,对应的公钥和私钥。这里我全部都拿Nginx服务器举例,Apache也不会差太多,都是基于openssl的。因为我只有一个主机域名www.ogeek.net,所以证书方便选择了COMODO的PositiveSSL,每年9刀。需要注意COMODO要求证书至少是2048位,见下面的命令。激活证书的时候需要注意common name那里要填写自己的域名地址,我因为并不使用ogeek.net,所以这里写的就是www.ogeek.net,需要注意这两个主机地址是不同的。其他的组织名公司名什么的如果没有就写NA,不要留空。下面简单说一下步骤
查看OpenSSL版本,确认至少在1.0.1h以上, openssl version -a 如果没有,升级服务器,以Debian为例 apt-get update apt-get upgrade 2、创建CSR和私钥 openssl req -new -newkey rsa:2048 -nodes -keyout www.ogeek.net.key -out www.ogeek.net.csr 得到2个文件,私钥www.ogeek.net.key,CSR文件www.ogeek.net.csr,其中CSR里面的内容在激活证书的时候需要提交 3、购买证书,完成激活,下载证书文件 下载的证书文件通常是一个压缩包,有些是2个文件,有些是4个文件 如果是2个文件,是这样的:
如果是4个文件,通常都是这样的:
其中www_slyar_com.ca-bundle就是自动合并了其他3个文件的产物,一个道理 4、合并证书,顺序一定不能错 cat www_ogeek_net.crt www_slyar_com.ca-bundle > www.ogeek.net.crt 或者 cat www_slyar_com.crt www_slyar_com.ca-bundle > www.ogeek.net.crt 最后产生的www.ogeek.net.crt是4个文件的合并,此文件与之前产生的www.ogeek.net.key一起组成了Nginx需要使用的证书 5、把www.ogeek.net.crt和www.ogeek.net.key复制到Nginx的conf目录下,比如/usr/local/nginx/conf/ cp www.ogeek.net.crt www.ogeek.net.key /usr/local/nginx/conf/ 6、修改Nginx配置文件或者vhost/下的虚拟主机配置文件,启用https,配置加密方式等 #合并80和443配置文件也可以,一起配置,最后强制转移80到443就可以了 listen 80; listen 443; #指定证书文件 ssl_certificate www.ogeek.net.crt; ssl_certificate_key www.ogeek.net.key; #禁用不安全的SSLv1 2 3,只使用TLS ssl_protocols TLSv1 TLSv1.1 TLSv1.2; ssl_prefer_server_ciphers on; #RC4也是不安全的了,只能去掉 ssl_ciphers EECDH+CHACHA20:EECDH+AES128:RSA+AES128:EECDH+AES256:RSA+AES256:EECDH+3DES:RSA+3DES:!MD5; #301转移 if ($server_port = 80) { return 301 https://$server_name$request_uri; } 7、测试Nginx配置文件并重新reload配置文件 Nginx -t service nginx reload 这样服务器的HTTPS就配置完了。 既然HTTPS非常安全,数字证书费用也不高,那为什么互联网公司不全部使用HTTPS呢?原因主要有两点: HTTPS对速度的影响非常明显。每个HTTPS连接一般会增加1-3个RTT,加上加解密对性能的消耗,延时还有可能再增加几十毫秒。 HTTPS为什么会严重降低性能?主要是握手阶段时的大数运算。其中最消耗性能的又是密钥交换时的私钥解密阶段(函数是rsa_private_decryption)。这个阶段的性能消耗占整个SSL握手性能消耗的95%。 然而随着各大网站的相继跟进与硬件的摩尔定律下,为了安全而做这点性能牺牲还是值得的。 |
请发表评论