Nginx服务器https如何配置
发布时间 - 2023-05-23 00:00:00 点击率:次申请证书
目前网上有不少机构提供个人免费 ssl 证书,有效期几个月到几年不等。以 startssl :https://www.startssl.com 为例, 申请成功后有效期 3 年,到期后可免费续租。
具体申请过程也很简单。
注册登录以后选择 certificates wizard >> dv ssl certificate 申请一个免费的 ssl 证书。
通过邮件验证域名之后,然后在自己服务器中生成 ssl 证书的 csr , 记住生成输入的秘密 ,之后要用到:
openssl req -newkey rsa:2048 -keyout weizhimiao.cn.key -out weizhimiao.cn.csr
将生成的证书,放到指定的存放证书的目录,如 /data/secret/ 。查看证书 weizhimiao.csr 内容,将内容复制到页面中的 certificate signing request (csr)部分,提交页面。
下载生成好的证书,选择对应的web服务器(nginx,1_weizhimiao.cn_bundle.crt),这样私钥和公钥我们就都有了。
1_weizhimiao.cn_bundle.crt(公钥)
weizhimiao.cn.key(私钥)
nginx配置(为指定域名增加https)
nginx.conf当前配置
...
http {
...
include /etc/nginx/conf.d/*.conf;
server {
...
}
}./conf.d/weizhimiao.cn.conf中加入
server{
listen 443 ssl;
server_name weizhimiao.cn;
ssl_certificate /data/secret/1_weizhimiao.cn_bundle.crt;
ssl_certificate_key /data/secret/weizhimiao.cn.key;
ssl_prefer_server_ciphers on;
ssl_protocols tlsv1 tlsv1.1 tlsv1.2;
ssl_ciphers 'keecdh+ecdsa+aes128 keecdh+ecdsa+aes256 keecdh+aes128 keecdh+aes256 kedh+aes128 kedh+aes256 des-cbc3-sha +sha !anull !enull !low !md5 !exp !dss !psk !srp !kecdh !camellia !rc4 !seed';
add_header strict-transport-security 'max-age=31536000; preload';
add_header x-frame-options deny;
ssl_session_cache shared:ssl:10m;
ssl_session_timeout 10m;
keepalive_timeout 70;
ssl_dhparam /data/secret/dhparam.pem;
add_header x-content-type-options nosniff;
add_header x-xss-protection 1;
root /data/www/weizhimiao.cn;
index index.html;
location / {
}
}注:
配置中用到一个 /data/secret/dhparam.pem 文件,该文件是一个pem格式的密钥文件,用于tls会话中。用来加强ssl的安全性。生成该文件方法,
cd /data/secret/ openssl dhparam 2048 -out dhparam.pem
将原来80端口的访问,重定向。./conf.d/weizhimiao.cn.conf中加入
server{
listen 80;
server_name weizhimiao.cn;
return 301 https://weizhimiao.cn$request_uri;
}测试
检测配置文件是否有语法错误,需要输入之前生成公钥时输入的密码。
nginx -t enter pem pass phrase: nginx: the configuration file /etc/nginx/nginx.conf syntax is ok nginx: configuration file /etc/nginx/nginx.conf test is successful
重启nginx(切记,reload不起作用)
nginx -s stop enter pem pass phrase: nginx enter pem pass phrase:
浏览器访问 weizhimiao.cn ,是否生效。
另,nginx配置了安全证书之后,nginx每次的reload、stop等操作都需要输入密码。
可以通过生成一个解密的key文件,替代原来key文件。
cd /data/secret/ openssl rsa -in weizhimiao.cn.key -out weizhimiao.cn.key.unsecure
替换 weizhimiao.cn.conf 中的 weizhimiao.cn.key 文件.
server {
...
s
sl_certificate /data/secret/1_weizhimiao.cn_bundle.crt;
ssl_certificate_key /data/secret/weizhimiao.cn.key.unsecure;
...
}之后每次在reload时,就不需要在输入密码了。
最后,用 ssllabs 来进行一下测试。
结果
# nginx
# https
# ssl
# 公钥
# 该文件
# 输入密码
# 是一个
# 几年
# 要在
# 也很
# 可以通过
# 要用
# 几个月
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel如何使用Eloquent ORM进行数据库操作?(CRUD示例)
Edge浏览器怎么启用睡眠标签页_节省电脑内存占用优化技巧
微信小程序 scroll-view组件实现列表页实例代码
laravel怎么配置和使用PHP-FPM来优化性能_laravel PHP-FPM配置与性能优化方法
详解jQuery中基本的动画方法
Laravel怎么判断请求类型_Laravel Request isMethod用法
laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法
Laravel API资源(Resource)怎么用_格式化Laravel API响应的最佳实践
php8.4header发送头信息失败怎么办_php8.4header函数问题解决【解答】
Laravel如何部署到服务器_线上部署Laravel项目的完整流程与步骤
Windows10怎样连接蓝牙设备_Windows10蓝牙连接步骤【教程】
,怎么在广州志愿者网站注册?
Laravel如何配置中间件Middleware_Laravel自定义中间件拦截请求与权限校验【步骤】
香港服务器如何优化才能显著提升网站加载速度?
Laravel如何使用Blade组件和插槽?(Component代码示例)
详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)
如何在阿里云部署织梦网站?
Laravel Artisan命令怎么自定义_创建自己的Laravel命令行工具完全指南
如何在局域网内绑定自建网站域名?
如何撰写建站申请书?关键要点有哪些?
标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南
Laravel怎么设置路由分组Prefix_Laravel多级路由嵌套与命名空间隔离【步骤】
韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐
Win11应用商店下载慢怎么办 Win11更改DNS提速下载【修复】
Laravel如何自定义分页视图?(Pagination示例)
Laravel如何处理异常和错误?(Handler示例)
如何基于云服务器快速搭建个人网站?
如何快速查询网站的真实建站时间?
如何快速生成专业多端适配建站电话?
文字头像制作网站推荐软件,醒图能自动配文字吗?
Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】
Python高阶函数应用_函数作为参数说明【指导】
Laravel如何创建自定义Facades?(详细步骤)
Laravel策略(Policy)如何控制权限_Laravel Gates与Policies实现用户授权
Mybatis 中的insertOrUpdate操作
百度输入法ai面板怎么关 百度输入法ai面板隐藏技巧
Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程
Laravel如何生成API文档?(Swagger/OpenAPI教程)
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
如何确保FTP站点访问权限与数据传输安全?
如何快速搭建高效可靠的建站解决方案?
Laravel如何使用Gate和Policy进行授权?(权限控制)
Laravel如何使用Socialite实现第三方登录?(微信/GitHub示例)
如何在Windows虚拟主机上快速搭建网站?
PHP的CURL方法curl_setopt()函数案例介绍(抓取网页,POST数据)
Laravel怎么配置.env环境变量_Laravel生产环境敏感数据保护与读取【方法】
Laravel如何配置和使用缓存?(Redis代码示例)
Laravel如何生成URL和重定向?(路由助手函数)


sl_certificate /data/secret/1_weizhimiao.cn_bundle.crt;
ssl_certificate_key /data/secret/weizhimiao.cn.key.unsecure;
...
}