線上的一個網站運行了一段時間,應領導要求,將其訪問方式更改成https加密方式。
更改成https後,網站訪問正常,但網站註冊功能不能正常使用了!php
通過排查,是nginx配置裏結合php部分漏洞了一個參數(fastcgi_param HTTPS )致使,添加上這個參數後,問題迎刃而解!
nginx支持https的配置時,須要在php區域配置中添加FastCGI服務,不然https不支持php文件。nginx
location ~ \.php$ {
root /var/www/vhosts/fff/main;
fastcgi_pass 127.0.0.1:9000;
fastcgi_read_timeout 30;
fastcgi_index fff.php;
fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
#include fastcgi_params;
include fastcgi.conf;
fastcgi_param HTTPS on; 【或者fastcgi_param HTTPS $https if_not_empty; 】
}
} 服務器
*******************************************************************************************網站
如何開啓 Nginx 的 SSL 或者 HTTPS呢?加密
你們有沒有試過使用HTTPS登錄 phpmyadmin 的時候會自動返回「The plain HTTP request was sent to HTTPS port」?spa
這是個 fastcgi 的配置問題!unix
解決方法:ip
location ~ .*\.(php|php5)?$
{
try_files $uri =404;
fastcgi_pass unix:/tmp/php-cgi.sock;
fastcgi_param HTTPS $https if_not_empty;
fastcgi_index index.php;
include fcgi.conf;
}字符串
解釋:io
不少人認爲使用 fastcgi_param HTTPS on;,這樣是沒錯啦,不過強迫使用這個參數,可能不太有效!
最好的答案是上面的配置(參考下面 nginx 官方的連接)
fastcgi_param HTTPS $https if_not_empty;
有 https 協議時才自動使用 https on,不然忽略這個參數。
內嵌的變量:
$https – 若是連接是 SSL 就返回 「ON」,不然返回空字符串。
if_not_empty; – 當參數有值時才傳遞到服務器
注意:這個 if_not_empty 額外參數只適合 Nginx 1.1.11 以後的版本