当前位置: 首页 > news >正文

使用ssl_certificate_by_lua指令动态加载证书

1、下载 OpenResty - 下载

根据自己系统选择下载,我的是64位

2、解压到目录

3、启动openresty 

进入解压后的目录,执行nginx.exe 

浏览器输入 http://localhost 查看是否正常。显示以下画面就表示没有问题。

接下来可以开始准备动态安装证书

4、使用openssl-win64生成测试证书(待补充)

openssl 下载地址 。 也可以使用csdn下载​​​​​​​

5、进入conf目录,编辑nginx.conf

#增加ssl server配置server {listen       443 ssl;server_name  localhost;ssl_certificate      cert/server.crt;ssl_certificate_key  cert/server.key;ssl_certificate_by_lua_file conf\cert\ssl.lua;ssl_session_cache    shared:SSL:1m;ssl_session_timeout  5m;ssl_ciphers  HIGH:!aNULL:!MD5;ssl_prefer_server_ciphers  on;location / {root   html;index  index.html index.htm;}}

6、编写ssl.lua , 放到conf/cert下

local ssl = require "ngx.ssl"-- 清除之前设置的证书和私钥
local ok, err = ssl.clear_certs()
if not ok thenngx.log(ngx.ERR, "failed to clear existing (fallback) certificates")return ngx.exit(ngx.ERROR)
end-- 获取证书内容,比如 io.open("my.crt"):read("*a")
local cert_data, err
cert_data = io.open("conf\\cert\\localhost.crt"):read("*a")
if not cert_data thenngx.log(ngx.ERR, "failed to get PEM cert: ", err)return
end-- 解析出 cdata 类型的证书值,你可以用 lua-resty-lrucache 缓存解析结果
local cert, err = ssl.parse_pem_cert(cert_data)
if not cert thenngx.log(ngx.ERR, "failed to parse PEM cert: ", err)return
endlocal ok, err = ssl.set_cert(cert)
if not ok thenngx.log(ngx.ERR, "failed to set cert: ", err)return
endlocal pkey_data, err
pkey_data = io.open("conf\\cert\\localhost.key"):read("*a")
if not pkey_data thenngx.log(ngx.ERR, "failed to get DER private key: ", err)return
endlocal pkey, err = ssl.parse_pem_priv_key(pkey_data)
if not pkey thenngx.log(ngx.ERR, "failed to parse pem key: ", err)return
endlocal ok, err = ssl.set_priv_key(pkey)
if not ok thenngx.log(ngx.ERR, "failed to set private key: ", err)return
end

http://www.lryc.cn/news/221699.html

相关文章:

  • Qt中Opencv转Qimage出现重影或者颜色不对
  • upload-labs-1
  • 【vite配置路径别名@】/启动配置
  • 3. List
  • Django初窥门径-oauth登录认证
  • 数学到底在哪里支撑着编程?
  • Python模块ADB的, 已经 pyadb
  • 猫头虎分享从Python到JavaScript传参数:多面手的数据传递术
  • 注解汇总:Spring 常用的注解
  • 合肥工业大学操作系统实验5
  • 基于SpringBoot+Vue的点餐管理系统
  • C# 继承,抽象,接口,泛型约束,扩展方法
  • mysql的备份和恢复
  • 【机器学习3】有监督学习经典分类算法
  • lv11 嵌入式开发 计算机硬件基础 1
  • 【Linux】vim
  • cstring函数
  • 【owt】p2p client mfc 工程梳理
  • pandas教程:Hierarchical Indexing 分层索引、排序和统计
  • Redis 扩展 RedisBloom 插件,解决缓存击穿、穿透
  • VBA技术资料MF80:选择文件及文件夹
  • 网络层:控制平面
  • Ubuntu 系统内核 kernel panic
  • 【flink】RowData copy/clone方式
  • 网页图标工具
  • 掌动智能:功能测试及拨测主要功能
  • 第11章 Java集合(二)
  • Transformer和ELMo模型、word2vec、独热编码(one-hot编码)之间的关系
  • 您与1秒钟测量两千个尺寸之间仅差一台智能测径仪!
  • k8s之service五种负载均衡byte的区别