Django的HttpResponseRedirect是http而不是https
我的服务器运行Django Gunicorn nginx. 我添加了SSL证书并配置了nginx以将http重定向到https.当收到https请求时,nginx将其作为http传递给Gunicorn. 我的程序有时返回HttpResponseRedirect,浏览器获得重定向响应并重新请求为http,因此nginx重定向到https. 我怎么能避免这个?如何配置服务器,以便第一个重定向直接指向https URL? 最佳答案 在nginx配置中(位置块内),指定:
proxy_redirect告诉nginx,如果后端返回HTTP重定向,它应该保持原样.默认情况下,nginx假设后端是愚蠢的,并试图变得聪明;如果后端返回一个称为“重定向到http://localhost:8000/somewhere”的HTTP重定向,则nginx将其替换为类似于http://yourowndomain.com/somewhere的内容.但Django并不是愚蠢的(或者它可以配置为不是愚蠢的). Django不知道请求是通过HTTPS还是普通HTTP发出的; nginx知道这一点,但随后它对Django后端的请求始终是纯HTTP.我们告诉nginx使用X-Forwarded-Proto HTTP头传递此信息,以便相关的Django功能(如request.is_secure())正常工作.您还需要在settings.py中设置SECURE_PROXY_SSL_HEADER =(‘HTTP_X_FORWARDED_PROTO’,’https’). (编辑:百色站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- django – 未创建uwsgi套接字文件
- 是否可以在不安装卷的情况下将请求传递给php-fpm
- NGINX-正则表达式-在整个位置搜索非字母数字
- ruby-on-rails – 如何从Nginx/Passenger中删除“X-Runtime
- Nginx反向代理:post_action如果代理缓存命中 – Possbile?
- php-Nginx损坏了下载的文件
- 我应该在nginx中使用rewrite或return或proxy_pass吗?
- node.js-端口号未隐藏在Nginx反向代理中(下一个JS服务器)
- django – 将应用程序级用户名/用户ID注入nginx/Apache日志
- 在Nginx中随机返回备用页面进行A / B测试