设为首页 收藏本站
查看: 1208|回复: 0

[经验分享] ssl(https)介绍、实验环境生成密钥对、nginx配置SSL、https

[复制链接]

尚未签到

发表于 2018-11-12 12:57:11 | 显示全部楼层 |阅读模式
ssl原理

http与https区别

  http默认端口为80,https默认端口为443;
  http传输数据为明文,https传输数据是加密的;

  http是HTTP协议运行在TCP之上。所有传输的内容都是明文,客户端和服务器端都无法验证对方的身份;
  https是HTTP运行在SSL/TLS之上,SSL/TLS运行在TCP之上。所有传输的内容都经过加密,加密采用对称加密,但对称加密的密钥用服务器方的证书进行了非对称加密。此外客户端可以验证服务器端的身份,如果配置了客户端验证,服务器方也可以验证客户端的身份。

https工作流程

  1.完成TCP三次同步握手
  2.客户端验证服务器的证书,通过,进入步骤3
  3.DH算法协商对称加密算法的秘钥、hash算法的秘钥
  4.SSL安全加密碎到协商完成;
  5.网页用加密方式传输,用协商的加密算法加密,保证数据完整和不被篡改;


生成ssl密钥对
  正常的网站https使用的ssl证书是需要购买的,我们做实验就只需要自己生成一个就行了,但是无法在网络上流通;

下载openssl生成软件
  

yum install -y openssl  

进入密钥对目录
  设置秘钥防止目录
  

cd /usr/local/nginx/conf/  

生成私钥
  注意这里要求设置密码
  

openssl genrsa -des3 -out tmp.key 2048  

转换为无密码的私钥
  注意:这里会提示要求输入老私钥文件tmp.key的密码;
  

openssl rsa -in tmp.key -out test.key  

  
删除老的私钥
  
rm -rf tmp.key
  

生成证书请求文件
  需要设置详细信息,可以直接回车默认
  

openssl req -new -key test.key -out test.csr  

设置公钥有效期,生成公钥
  

openssl x509 -req -days 365 -in test.csr -signkey test.key -out test.crt  

  

  注意:test.crt才是公钥,test.csr只是请求文件,test.key是私钥;


nginx配置SSL

创建ssl配置文件
  

vim /usr/local/nginx/conf/vhost/ssl.conf  

  代码
  

server  
{
  listen 443;                         //设置端口为443
  server_name shu.com;                //设置网站域名为shu.com
  index index.html index.php;
  root /data/wwwroot/shu.com;         //设置web的站点目录
  ssl on;                             //开启ssl功能
  ssl_certificate test.crt;           //指定公钥名字
  ssl_certificate_key test.key;       //指定私钥名字
  ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
  
}
  

检测与生效
  

/usr/local/nginx/sbin/nginx -t
  
/usr/local/nginx/sbin/nginx -s>  

测试
  查看监听端口,有443则成功
  

netstat -lntp  

  使用https://shu.com访问,成功;

ssl错误处理:
  在-t检测时,错误提示
  

nginx: [emerg] unknown directive "ssl" in /usr/local/nginx/conf/vhost/ssl.conf:7  
nginx: configuration file /usr/local/nginx/conf/nginx.conf test failed
  

  
提示:nginx不支持ssl,这是因为我们编译安装nginx时是最简单的模式编译的,没有指定ssl;
  

思路:
  重新编译安装nginx

查看nginx之前编译的参数
  

/usr/local/nginx/sbin/nginx -V  

nginx version: nginx/1.12.2  
built by gcc 4.8.5 20150623 (Red Hat 4.8.5-16) (GCC)
  
configure arguments: --prefix=/usr/local/nginx
  

进入源码包
  

cd /usr/local/src/nginx-1.12.2/  

查询ssl需要增加配置
  

./configure --help |grep -i ssl  

  
结果为:--with-http_ssl_module
  

重新编译nginx
  

./configure --prefix=/usr/local/nginx --with-http_ssl_module  
make && make install
  

重启nginx服务
  

/etc/init.d/nginx restart


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-634175-1-1.html 上篇帖子: 三大主流软件负载均衡器对比(LVS、Nginx、HAproxy) 下篇帖子: Nginx快速入门视频课程——笔记
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表