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’). (编辑:十堰站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- 安全-确保Elasticsearch
- 外部托管的Nginx代理图像/ javascript
- ruby-on-rails-使用Passenger和Nginx将Rails应用程序部署到
- Nginx.如果为空URI.如果为空域.位置.正则表达式
- Laravel Homestead vhost配置
- Nginx反向代理中的SSL传递?
- node.js – 无法使用gzip为nginx中的分块传输编码关闭从Nod
- apache – NGINX配置与Socket.IO一起使用
- ruby-on-rails-为什么SSL重定向不能与force_ssl和Nginx一起
- django – 将应用程序级用户名/用户ID注入nginx/Apache日志