Django-channels websocket在AWS服务器上运行良好,直到我安装了letsencript ssl。我尝试了另一个证书,但是wss无效。我看到这个在线部署显示渠道可以在https:
之后工作https://django-channels-example.herokuapp.com/
我跟着andrewgodwin sugestions在这里:
https://github.com/django/channels/issues/248
我把daphne指向了端口8000:
daphne -b 0.0.0.0 vp.asgi:channel_layer --port 8000 -v 2
我在javascript中使用了相同的端口:
chatsock = new WebSocket( ws_scheme + '://' + window.location.host + ":8000/chat" );
我的nginx配置:
server {
listen 80;
server_name mysite.com www.example.com;
return 301 https://www.example.com$request_uri;
}
server{
listen 443 ssl;
server_name mysite.com www.example.com;
ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem;
root /home/ubuntu/vp;
access_log /var/log/nginx/guni-access.log;
error_log /var/log/nginx/guni-error.log info;
location /wss/ {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-for $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_pass http://0.0.0.0:8000;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
}
location / {
proxy_pass http://0.0.0.0:8000;
proxy_set_header HOST $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-for $remote_addr;
proxy_set_header X-Forwarded-Proto $scheme;
port_in_redirect off;
proxy_connect_timeout 300;
}
location ~ /.well-known {
allow all;
}
location /static/ {
alias /home/ubuntu/vp/static/;
expires 30d;
}
}
我的浏览器告诉您:
Firefox无法在wss://example.com:8000 / chat。
建立与服务器的连接有什么建议吗? 谢谢。
答案 0 :(得分:3)
我建议你改变你的东西。
的javascript:
var ws_scheme = window.location.protocol == "https:" ? "wss" : "ws";
var chatsock = new ReconnectingWebSocket(ws_scheme + '://' + window.location.host + window.location.pathname);
nginx的:
server {
listen 443 ssl;
server_name server.domain.com;
ssl on;
ssl_certificate /path_to_server_certificate.crt;
ssl_certificate_key /path_to_server_key.key;
## static files (path should be changed)
location /static/ {
autoindex off;
alias /blabla/static/;
}
## app
location / {
proxy_pass http://127.0.0.1:8000;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_set_header Host $host;
}
}