2

node jsを使用するのはこれが初めてです。クライアントをサーバーに接続させ、閉鎖せずに接続を維持しようとしています。

これはすべて、virtualbox でホストされている ubuntu サーバー エディションでホストされています。

netstat -ant を使用して、サーバーが実際にポート 5000 をリッスンしていることを確認しました。

私のブラウザでは Websockets も利用できます。

次の出力がエラーで表示されます

Echo server dot come
192.168.1.107
node.js:134
        throw e; // process.nextTick error, or 'error' event on first tick
        ^
Error: EPIPE, Broken pipe
    at Socket._writeImpl (net.js:159:14)
    at Socket._writeOut (net.js:450:25)
    at Socket.write (net.js:377:17)
    at Socket.ondata (stream.js:36:26)
    at Socket.emit (events.js:81:20)
    at Socket._onReadable (net.js:678:14)
    at IOWatcher.onReadable [as callback] (net.js:177:10)

そして、接続イベントハンドラーでサーバー上で socket.end() を呼び出すと、クライアントが切断されます。私の質問は、このコードを使用して安定した接続を確立する方法です。何を変更する必要がありますか、またはここで間違っていますか? 髪を引っ張る - 前もって感謝します!

HTMLコード

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Strict//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Test RS Server (built over nodejs)</title>
<link rel="stylesheet" href="style.css"></link> 
<script src="jquery.min.js" ></script>
<script src="client.js" ></script>
</head>
<body>
<label>Message</label>
<input type="text" id="message_box"></input>
<input type="button" id="submit_btn" value="Send"></input>
<div style="clear:both;"/>
<label>Output</label>
<textarea rows="10" cols="100" id="output_box"></textarea>

</body>
</html>

クライアントJS

var message_box; 
var output_box;
var submit_btn;
var url = "wss://192.168.1.107:5000";
var socket;

function createListeners() {
    if ("WebSocket" in window) {
        output_box.html("Supports sockets.");
        socket= new WebSocket(url);
        socket.onopen= function() {
            socket.send("con opened");
            output_box.html("Connection opened.");
        };
        socket.onmessage= function(response) {
            //  alert('got reply '+s);
            console.log(response);
            output_box.html(response);
        };
        socket.onclose = function() { 
            // websocket is closed.
            output_box.html("Connection is closed..."); 
        };
        submit_btn.click(function(e) {
            socket.send(message_box.val());
        });
    } else {
        output_box.html("doesnt support sockets");
    };
};

$(document).ready(function() {
    message_box = $("#message_box");
    output_box = $("#output_box");
    submit_btn = $("#submit_btn");
    createListeners();
});

サーバー JS コード

var net = require('net');
var server = net.createServer(function (socket) {
    socket.write('server says this\r\n');
    socket.pipe(socket);
});
server.on('connection', function(socket) {
    socket.write("Echo server dot come\r\n"+socket.address().address);
    console.log("Echo server dot come\r\n"+socket.address().address);
    // socket.end();
    socket.pipe(socket);
});
server.listen(5000);
4

1 に答える 1

2

単純な TCP サーバーで WebScoket クライアントを使用しようとしています。これは異なるプロトコルです。動作させるには、WebSocket サーバーをセットアップする必要があります。これを行うには、 websocketモジュールを使用できます。ここでサーバーのサンプルコードを見てください。

于 2013-04-06T15:21:47.073 に答える