Nginx 对上游使用SSL链接
L96
双向认证SSL指令示列
对下游使用证书指令
| Syntax: | ssl_certificate |
|---|---|
| Default: | — |
| Context: | http, server |
| Syntax: | ssl_certificate_key |
|---|---|
| Default: | — |
| Context: | http, server |
代码示列 首先需要将 ngx_http_ssl_module编译进nginx 一般证书可以动态生成 详见 SSL证书生成方式
listen ssl; # managed by Certbot ssl_certificate /etc/letsencrypt/live/shoppas.com.cn/fullchain.pem; # managed by Certbot ssl_certificate_key /etc/letsencrypt/live/shoppas.com.cn/privkey.pem; # managed by Certbot include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot
如何验证下游证书
| Syntax: | ssl_client_certificate |
|---|---|
| Default: | — |
| Context: | http, server |
| Syntax: | ssl_verify_client |
|---|---|
| Default: |
ssl_verify_client off; |
| Context: | http, server |
如何对上游使用证书 如果需要链接上游 可以在location设置独立的证书
| Syntax: | proxy_ssl_certificate |
|---|---|
| Default: | — |
| Context: | http, server, location |
| Syntax: | proxy_ssl_certificate_key |
|---|---|
| Default: | — |
| Context: | http, server, location |
如何验证上游的证书
| Syntax: | proxy_ssl_trusted_certificate |
|---|---|
| Default: | — |
| Context: | http, server, location |
| Syntax: | proxy_ssl_verify |
|---|---|
| Default: |
proxy_ssl_verify off;
|
| Context: | http, server, location |
SSL模块提供的变量
- ssl_cipher : 本次通讯选用的安全套件
- ssl_ciphers : 客户端支持的所有安全套件
- ssl_protocal : 本次通讯选用的 TLS 版本
- ssl_curves:客户端支持的椭圆曲线
证书
- ssl_client_raw_cert: 原始客户端证书内容
- ssl_client_escaped_cert:返回客户端证书做urlencode编码后的内容
- ssl_client_cert:对客户端证书每一行内容前加tab制表符空白,增强可读性
- ssl_client_fingerprint:客户端证书的SHA1指纹
证书结构化信息
- ssl_server_name 通过TLS插件SNI获取到服务域名
- ssl_client_i_dn 依据RFC2253获取到证书issuer nd信息 如: CN=...,O=...,L=...,C=..,
- ssl_client_i_dn_legacy 依据RFC2253获取到证书issuer nd信息 如: /CN=.../O=.../L=.../C=...
- ssl_client_s_dn 依据RFC2253获取到证书subject dn信息
- ssl_client_s_dn_legacy 依据RFC2253获取到证书subject dn信息 格式不一样而已
证书有效期
- ssl_client_v_end 返回客户端正式的过期时间
- ssl_client_v_ramain 返回还有多少天客户端证书过期
- ssl_client_v_start 客户端证书颁发时间
链接有效性
ssl_client_serial 返回连接上客户端证书的序列号
ssl_early_data 在TLS1.3协议中使用early data且握手未完成返回1 否则返回空字符串
ssl_client_verify 如果验证失败为FAILED原因 如果没有验证证书则为NONE 验证成功为SUCCESS
ssl_session_id 已经建立连接的sessionId
ssl_session_reused 如果session被复用 则为r 否则为.
创建证书示列
创建根证书
创建CA私钥命令 : openssl genrsa -out ca.key 2048
创建CA公钥 :openssl req -new -x509 -days 3650 -key ca.key -out ca.crt //后面可能让输入很多选项 比如国家 城市 等
签发证书
创建私钥
openssl genrsa -out a.pem 1024 //创建证书a
openssl rsa -in a.pem -out a.key //创建a证书的公钥
生成签发请求
openssl req -new -key a.pem -out a.csr //针对a证书做签发
使用CA证书进行签发
openssl x509 -req -sha256 -in a.csr -CA ca.crt -CAKey ca.key -CAcreateserial -days 3650 -out a.crt //使用ca证书来签发a证书
验证签发证书是否正确
openssl verify -CAfile ca.crt a.crt
Nginx 对上游使用SSL链接的更多相关文章
- Ubuntu Nginx下配置网站ssl实现https访问
最近在看 HTTP权威指南 看到介绍了HTTPS的ssl,自己就动手测试了下,将步骤记录下 HTTPS简介 什么是HTTPS?百科是这样解释的.HTTPS(全称:Hyper Text Trans ...
- Nginx集群之SSL证书的WebApi微服务
目录 1 大概思路... 1 2 Nginx集群之SSL证书的WebApi微服务... 1 3 HTTP与HTTPS(SSL协议)... 1 4 Ope ...
- Nginx集群之SSL证书的WebApi身份验证
目录 1 大概思路... 1 2 Nginx集群之SSL证书的WebApi身份验证... 1 3 AuthorizeAttribute类... 2 4 ...
- Nginx集群之SSL证书的WebApi令牌验证
目录 1 大概思路... 1 2 Nginx集群之SSL证书的WebApi令牌验证... 1 3 Openssl生成SSL证书... 2 4 编写.NE ...
- Linux下Nginx配置阿里云 SSL证书实现HTTPS访问
这篇文章主要介绍了nginx配置ssl证书实现https访问的示例 1.服务器系统:Centos 2. 阿里云申请SSL证书 选择“免费版DV SSL”,点击立即购买: 下载证书 列表中找到已签发的证 ...
- nginx:[emerg]unknown directive "ssl"
nginx: [emerg] unknown directive "ssl" in /usr/local/nginx/conf/nginx.conf:102 到解压的nginx目录 ...
- Nginx 接受上游缓存流程
L:101 这个指令主要是由上游服务器来决定是否缓存 详见博客Nginx 针对上游服务器缓存
- Nginx 当上游服务器返回失败时的处理办法
陶辉95课 Syntax: proxy_next_upstream error | timeout | invalid_header | http_500 | http_502 | http_503 ...
- Linux 搭建Nginx并添加配置 SSL 证书
1. 安装准备 1.1 gcc安装 安装 nginx 需要先将官网下载的源码进行编译,编译依赖 gcc 环境,如果没有 gcc 环境,则需要安装: [root@nginx ~]# yum -y i ...
随机推荐
- face detection[PyramidBox]
本文来自<PyramidBox: A Context-assisted Single Shot Face Detector>,是来自百度的作品,时间线为2018年8月. 0 引言 最近基于 ...
- Hadoop Yarn调度器的选择和使用
一.引言 Yarn在Hadoop的生态系统中担任了资源管理和任务调度的角色.在讨论其构造器之前先简单了解一下Yarn的架构. 上图是Yarn的基本架构,其中ResourceManager是整个架构的核 ...
- 多模块调用Service失败
最近在搭一个基础架构,整合项目. 在做多模块中调用的时候,在@Autowired的时候找不到service的bean. 解决方案: 需要在启动类加入扫描 @SpringBootApplication( ...
- Nginx服务器的使用与反向代理负载均衡
目录 Nginx服务器 一:什么是Nginx? 什么是Nginx - Nginx与其他服努器的性能比较 二:如何在Linux中搭建Nginx服务器? 常见的错误 三:Nginx的反向代理和负载均衡 什 ...
- 读写分离子系统 - C# SQL分发子系统 - Entity Framework支持
A2D Framework增加了EF支持,加上原先支持ADO.NET: 支持EF方式 支持ADO.NET方式 这次来讲如何让Entity Framework变成nb的读写分离 1. 先设计EF模型, ...
- [翻译] C# 8.0 新特性
原文: Building C# 8.0 [译注:原文主标题如此,但内容大部分为新特性介绍,所以意译标题为 "C# 8.0 新特性"] C# 的下一个主要版本是 8.0.我们已经为它 ...
- MySQL定时备份数据库(全库备份)
一.MySQL数据备份 1.1. mysqldump命令备份数据 在MySQL中提供了命令行导出数据库数据以及文件的一种方便的工具mysqldump,我们可以通过命令行直接实现数据库内容的导出dump ...
- .NET开源项目 QuarkDoc 一款自带极简主义属性的文档管理系统
有些话说在前头 因为公司产品业务重构且功能拆分组件化,往后会有很多的接口文档需要留存,所以急需一款文档管理系统.当时选型要求3点: 1.不能是云平台上的Saas服务,整个系统都要在自己公司部署维护(数 ...
- Linux Namespace : UTS
UTS namespace 用来隔离系统的 hostname 以及 NIS domain name.UTS 据称是 UNIX Time-sharing System 的缩写. hostname 与 N ...
- 小L的试卷
题目描述 小L期末考试结束,高高兴兴放假回家了,可是那么多试卷,老师还要加班批改,有n份试卷由k个老师批改,n份试卷进行了密封编号,由于试卷上的做题情况和书写的规范程序不一样,批改不同的试卷用时也可能 ...