5

我目前正在使用线程标题中提到的技术开展一个项目。

我从浏览器中运行它(应用程序托管在 heroku 上),但是当我尝试从 Ionic 2 应用程序连接到 websockets 时,我总是在建立握手时遇到错误。

2016-09-17T15:02:03.200133+00:00 app[web.1]: 2016-09-17 15:02:03,199 DEBUG    Connection http.response!uvRVDyvolYEG did not get successful WS handshake.

2016-09-17T15:02:03.200498+00:00 app[web.1]: 2016-09-17 15:02:03,200 DEBUG    WebSocket closed before handshake established

2016-09-17T15:02:03.169206+00:00 heroku[router]: at=info method=GET path="/1/" host=musicmashup-jukebox.herokuapp.com request_id=c46960d7-bb8f-45bf-b8be-5a934c771d96 fwd="212.243.230.222" dyno=web.1 connect=0ms service=7ms status=400 bytes=74

现在一个想法是,这可能是一个 CORS 问题。所以我安装django-cors-middleware了希望这可以解决问题 - 好吧它没有。但我认为该应用程序根本不会向 Daphne 服务器添加任何标头。

目前我不知道问题是在客户端还是在服务器端。

有没有人遇到过类似的问题?

编辑:发现 websockets 和 CORS 没有任何关系为什么 WebSockets 没有同源策略?为什么我可以连接到 ws://localhost? 所以我的猜测是,服务器可能会拒绝客户端发送的原始标头。我会看看我是否可以得到正在发送的标题

4

3 回答 3

1

此问题已在 Daphne v.1.0.3 https://github.com/django/daphne/commit/07dd777ef11f5091931fbb22bdacb9e4aefea7da中修复

如果使用,您还需要更新频道和 asgi-redis。

于 2017-03-15T12:32:20.470 回答
0

好吧,这个问题在某种程度上与源头有关。Ionic 似乎正在发送一个包含“file://..”的原始标头,该标头被 websocket 服务器拒绝/阻止。

不幸的是,我没有找到一种方法来配置 heroku 上的网络服务器以忽略这一点或在传入数据包上设置另一个源头。

我在heroku上的Procfile:

web: daphne app.asgi:channel_layer --port $PORT--bind 0.0.0.0 -v2
worker: python manage.py runworker -v2

我当时所做的是将整个应用程序移动到一个自托管的 Ubuntu 服务器上,并在 Daphne 前面放置一个 nginx,在那里我创建了一个规则来覆盖传入数据包的原始标头。

就是这样。我希望这可以帮助一些人。

于 2016-09-17T23:06:18.013 回答
0

谢谢你,

它使用以下 nginx 规则对我有用:

proxy_set_header Origin http://$host;
于 2017-01-03T22:08:14.777 回答