nginx对特别的url实现https

发布于 2022-09-01 21:11:06 字数 419 浏览 15 评论 0

有一个接口的系统 都是http的请求 我现在像把例如带有login passwd的url进行ssl ,例如app调用os.test.com/a/p/login的时候走https请求 但是其它的请求还是走http请求 现在用openssl配置了证书 私钥等 但是现在每个请求都走了https请求 如
server {

listen      443;
server_name  os.test.com;
ssl on;
ssl_certificate /etc/ngx/conf.d/server.crt;
ssl_certificate_key /etc/ngx/conf.d/server.key;
location / {
    proxy_pass http://127.0.0.1:9988;
}

}
这个应该怎么去修改

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

蓝色星空 2022-09-08 21:11:06

你要分开写,先创建一个server专门处理https请求, 然后根据url反向代理过去就行了, 下面是代码:

处理非https请求,https请求反向代理出去

server {

listen      443;
server_name  os.test.com;
location / {

}

location ~* .(login|passwd)$ {
    proxy_pass http://127.0.0.1:9999
}

}

处理https请求

server{

listen 9999
server_name 127.0.0.1
ssl on;
ssl_certificate /etc/ngx/conf.d/server.crt;
ssl_certificate_key /etc/ngx/conf.d/server.key;
location / {
 
}

}

初相遇 2022-09-08 21:11:06
# http
server {
    listen 80;
    
    location /login {
        rewrite ^  https://$host$request_uri permanent;
    }
}

# https
server {
    listen 443;
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文