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

[经验分享] 基于Nginx配置https证书

[复制链接]

尚未签到

发表于 2018-11-13 13:26:30 | 显示全部楼层 |阅读模式
  关于平台配置https证书
  准备内容:
  1、授权可以的证书文件
  2、Nginx上配置证书
  3、后端iis上站点上配置证书
  4、程序代码调整判断
  一、在Nginx上配置证书
DSC0000.png DSC0001.png

  listen      443 ssl;
  ssl on;
  ssl_certificate /usr/local/nginx/keys/xxx.com.pem;
  ssl_certificate_key /usr/local/nginx/keys/xxx.com.key;
  ssl_session_timeout  5m;
  ssl_protocols  SSLv3 TLSv1;
  ssl_ciphers  HIGH:!ADH:!EXPORT56:RC4+RSA:+MEDIUM;
  ssl_prefer_server_ciphers   on;
  server_name  xxx.xxx.com;
  index index.html;
  access_log logs/ssl.lan.xxx.xxx.com access_log;
  在Nginx中,配置的负载后端服务信息
DSC0002.png

  这里需要注意在proxy_pass配置中, 需要使用https方式

  二、iis上配置证书
  1、导入证书
  打开mmc控制台,添加证书配置项
DSC0003.png

  通过导入对应的证书文件, 导入“个人”,“中级证书颁发机构”  这2个节点都需要导入操作。
DSC0004.png

  2、应用站点配置证书
  在前面的正确导入证书后,配置站点时选择https类型后,在SSL证书中,就可以看到导入成功的证书信息
  这里需要注意的是证书授权的域名需要相同,并且对应二级域名不要多个“ . "号出现
  这里的配置端口30011,这个是提供给Nginx配置中,负载使用的
DSC0005.png

  说明:这里的主机名,可以不配置,在nginx负载时,可以通过ip和端口找到
  三、程序中配置支持https
  程序中,相关的考试,计时,视频,登录相关地址,根据当上下文中的IsSecureConnection 判断连接信息
  //
  // 摘要:
  //     获取一个值,指示 HTTP 连接是否使用安全套接字(即 HTTPS)。
  //
  // 返回结果:
  //     如果连接是 SSL 连接,则为 true;否则为 false。
  public bool IsSecureConnection { get; }
DSC0006.png

  对应的web.config中配置相应的节点,这里主要是考虑支持http, https 两种不同方式支持,在再则会方便测试环境中存在2种地址不同情况,因为做了2个节点的配置,正式使用时,理论上2种类型的域名地址配置的是相同的。
(可以根据类型配置不同的资源地址)

  在平台中,如登录使用的是cas服务, 平台侧与cas进行验票后,web.config需要进行如下配置:

  
  
  
  
  
  
  在web.config中,增加如上节点的配置,否则会出现以下异常信息,造成用户登录不了

  Ticket validation error: DotNetCasClient.Validation.TicketValidationException: CAS server ticket validation threw an Exception ---> System.Net.WebException: 服务器提交了协议冲突. Section=ResponseHeader Detail=CR 后面必须是 LF
  附加说明:
  1、针对使用DotNetCasClient组件时,如果需要看相应日志信息,需要对web.config增加如下配置
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  以下是平台的nginx配置
  server {
  listen      443 ssl;
  ssl on;
  ssl_certificate /usr/local/nginx/keys/xxx.com.pem;
  ssl_certificate_key /usr/local/nginx/keys/xxx.com.key;
  ssl_session_timeout  5m;
  #ssl_protocols  SSLv3 TLSv1;
  ssl_protocols  TLSv1 TLSv1.1 TLSv1.2;
  ssl_ciphers  HIGH:!ADH:!EXPORT56:RC4+RSA:+MEDIUM;
  ssl_prefer_server_ciphers   on;
  server_name  xxx.xxx.com;
  index index.html;
  access_log logs/ssl.lan.xxx.xxx.com access_log;
  配置永久http重定向https
  [dangzheng@db1 extra]$ cat xxx-http-test.conf
  server {
  listen       80;
  server_name  xxx.xxx.com;
  access_log logs/xxx.xxx.com.access.log access_log;
  location / {
  rewrite ^(.*) https://xxx.xxx.com/$1 permanent;
  }
  }
  permanent  表示永久重定向
  $1   表示域名后带的参数信息
  配置参考:http://blog.csdn.net/zhanglinjian21/article/details/7631515
  配置Nginx 中的 default
  解决低版本(xp ie8类似)浏览器,只能认到1个https证书问题,如果没有配置,有多个证书时,浏览器访问就会有可能找到不正确的证书,经起访问不正常现象

  五、SSL配置优化
  1、HSTS
  HSTS(HTTP Strict Transport Security)。服务端返回一个 HSTS 的 http header,浏览器获取到 HSTS 头部之后,在一段时间内,不管用户输入 www.baidu.com 还是 http://www.baidu.com ,都会默认将请求内部跳转成https://www.baidu.com;
  将下述行添加到你的 HTTPS 配置的 server 块中:
  add_header Strict-Transport-Security "max-age=31536000";
  ssl_session_cache    shared:SSL:20m;
  ssl_session_timeout  20m;
  参照Nginx的官方文档1MB内存大约可以存储4000个session,按例配置20M大约可以存储80000。根据需求合理设置
  ssl_prefer_server_ciphers On; #指定服务器密码算法在优先于客户端密码算法时
  既需要https,也需要http,http需要跳转到https
  新版本,重新创建新的server配置
  server {
  listen 80;
  server_name www.域名.com;
  return 301 https://$server_name$request_uri;(进行跳转)
  }
  server {
  listen 443 ssl;
  server_name www.域名.com;
  ssl_certificate /usr/share/nginx/html/zhengshu/XX.XX.crt;(证书)
  ssl_certificate_key /usr/share/nginx/html/zhengshu/XX.XX.key;(证书密钥)
  }


运维网声明 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.yunweiku.com/thread-634639-1-1.html 上篇帖子: nginx增加跨域配置header-Tenderrain 下篇帖子: php+nginx环境 两错误解决
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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