http://socket.io/#how-to-useからnginx リバース プロキシの背後にある最初の socket.io の例「ノード HTTP サーバーでの使用」をセットアップしました。httpに保存している限り、これは期待どおりに機能します。nginx 書き換えルールを導入して http を https (nginx で終了) に書き換えると、正しく動作しません。
クライアントの console.log には次のように表示されます。
SecurityError: The operation is insecure. socket.io.js (line 2371)
this.websocket = new Socket(this.prepareUrl() + query);
TypeError: this.websocket is undefined socket.io.js (line 2438)
this.websocket.close();
私はnodejsとnginxにかなり慣れていないので、基本的な間違いを犯している可能性がありますが、何時間もの実験とグーグル検索の後でも、完全に機能させることはできません.
Nginx (v1.4.1) 構成ファイル:
upstream dev {
server 127.0.0.1:8001;
}
server {
# Listen on 80 and 443
listen 80;
listen 443 ssl;
server_name _;
ssl_certificate /etc/ssl/certs/ssl-cert-snakeoil.pem;
ssl_certificate_key /etc/ssl/private/ssl-cert-snakeoil.key;
access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log;
location /dev/ {
if ($ssl_protocol = "") {
rewrite ^ https://$host$request_uri? permanent;
}
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header Host $http_host;
proxy_set_header X-NginX-Proxy true;
proxy_pass http://dev/;
proxy_redirect off;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
}
}
index.html:
<script src="./socket.io/socket.io.js"></script>
<script>
var socket = io.connect('http://'+window.location.host+':8001');
socket.on('news', function (data) {
console.log(data);
socket.emit('my other event', { my: 'data' });
});
</script>
サーバー.js:
var app = require('http').createServer(handler)
, io = require('socket.io').listen(app)
, fs = require('fs')
app.listen(8001);
function handler (req, res) {
fs.readFile(__dirname + '/index.html',
function (err, data) {
if (err) {
res.writeHead(500);
return res.end('Error loading index.html');
}
res.writeHead(200);
res.end(data);
});
}
io.sockets.on('connection', function (socket) {
socket.emit('news', { hello: 'world' });
socket.on('my other event', function (data) {
console.log(data);
});
});