0

php websocketサーバーをnode.jsにページングしていますが、ハンドシェイクが失敗する理由がわかりません。これが私のコードです:

var msg = data;
//console.log(msg);

tmp = msg.match(/\r\n\r\n(.*?)$/);
if(tmp) code = tmp[1];

tmp = msg.match(/GET (.*?) HTTP\/1.1/);
if(tmp) res = tmp[1];

tmp = msg.match(/Sec-WebSocket-Key1: (.*?)\r\n/);
if(tmp) key1 = tmp[1];

tmp = msg.match(/Sec-WebSocket-Key2: (.*?)\r\n/);
if(tmp) key2 = tmp[1];

tmp = msg.match(/Host: (.*?)\r\n/);
if(tmp) host = tmp[1];

tmp = msg.match(/Origin: (.*?)\r\n/);
if(tmp) origin = tmp[1];

tmp = msg.match(/Upgrade: (.*?)\r\n/);
if(tmp) upgrade = tmp[1];

tmp = msg.match(/Connection: (.*?)\r\n/);
if(tmp) connection = tmp[1];

tmp = key1.match(/[0-9]/g);
num1 = parseInt(tmp.join(''));

tmp = key2.match(/[0-9]/g);
num2 = parseInt(tmp.join(''));

tmp = key1.match(/\s/g);
spa1 = tmp.length;

tmp = key2.match(/\s/g);
spa2 = tmp.length;

part1 = num1/spa1;
part2 = num2/spa2;

var md5 = crypto.createHash('md5');

test1 = String.fromCharCode(part1 >> 24 & 0xFF, part1 >> 16 & 0xFF, part1 >> 8 & 0xFF, part1 & 0xFF);
md5.update(test1);  

test2 = String.fromCharCode(part2 >> 24 & 0xFF, part2 >> 16 & 0xFF, part2 >> 8 & 0xFF, part2 & 0xFF);
md5.update(test2);

md5.update(code);

var fin = md5.digest('binary');

var out = "HTTP/1.1 101 Web Socket Protocol Handshake\r\n"+'Upgrade: '+upgrade+"\r\n"+'Connection: '+connection+"\r\n"+'Sec-WebSocket-Origin: '+origin+"\r\n"+'Sec-WebSocket-Location: ws://'+host+res+"\r\n\r\n"+fin;

console.log(out);
socket.write(out, 'utf8');

誰かがアイデアを持っているなら、私は面白がるでしょう:)ハンドシェイクメソッドのv76仕様で与えられた例でこのコードを試してみました。

4

1 に答える 1

2

詳細については、 phpwebsocketを参照してください。

また、最新のWebSocketプロトコルバージョン[draft-ietf-hybi-thewebsocketprotocol-09では、ハンドシェイクメカニズムが更新され、「Sec-WebSocket-Key」は1つだけになります。改訂されたハンドシェイクメカニズムについては、私の記事から詳しく知ることができます。 : http: //www.codeproject.com/KB/HTML/Web-Socket-in-Essence.aspx

于 2011-06-28T16:04:43.460 に答える