我正在尝试让Nginx将传入的请求重写为我的服务器,前缀为https://到http://(这是因为此站点上使用的CMS强制URI而不是相对路径 – 基本上打破了整个站点通过使图像,脚本和样式表不可用).
我目前正在尝试改进前任制定的现有指令,但我发现自己受限于我对Nginx配置语法的了解.这是代码:
if ($ssl_protocol = "") {
rewrite ^ https://$http_host$request_uri? permanent;
}
我当前评论了这段代码,以防止强制重写http://到https://,但我不能在不破坏网站的情况下撤销该过程.这是我到目前为止所尝试的内容:
if ($ssl_protocol = "https") {
rewrite ^ http://$http_host$request_uri? permanent;
}
和
# also tried ($ssl_protocol != "")
if (!($ssl_protocol = "")) {
rewrite ^ http://$http_host$request_uri? permanent;
}
第一个似乎没有效果.发送到客户端的HTML仍会生成未被重写的HTTPS请求.
第二个片段似乎也没有任何效果 – 如果我理解正确(尽管我仍然有些惊讶),Nginx不支持布尔否定.
这样做的最佳方式(或工作方式)是什么?
最佳答案
更干净的方式是:
if ( $scheme = "https" ) {
return 301 http://example.com$request_uri
或者在那个和Nathans之间的某个地方回答,你的默认ssl服务器块只包含返回301(无论哪个ssl块,你都要仔细看看你的,看看它是如何实现和适应的)没有必要做正则表达式用于简单的重定向
返回 – http://nginx.org/en/docs/http/ngx_http_rewrite_module.html#return
编辑:我刚刚注意到有一个变量$https可以在if语句中使用.如果不是https,则返回“”:
if ( $https = "on" ) {
...
请记住,在测试更改时,您应该使用302临时重定向而不是301永久重定向,以便在您发现提前一小时修复它时保存拔毛,但更改未反映在您的浏览器中:)