最も簡単なSocket.ioの例の例は何ですか?


113

だから、私は最近Socket.ioを理解しようとしていますが、私はすばらしいプログラマではありません。Webで見つけることができるほとんどすべての例(何時間も探していたと思います)には、物事を複雑にする追加の要素があります。多くの例では、私を混乱させたり、奇妙なデータベースに接続したり、コーヒースクリプトや大量のJSライブラリを使用して混乱させたりすることがたくさんあります。

私は、サーバーが10秒ごとにクライアントに何時であるかを伝えるメッセージを送信し、クライアントがそのデータをページに書き込むか、非常に単純なアラートをスローする、基本的で機能的な例を見たいと思います。次に、そこから物事を理解し、db接続などの必要なものを追加できます。そして、はい、socket.ioサイトで例を確認しましたが、それらは私にとっては機能せず、それらが何をするのか理解できません。


4
socket.io/#how-to-use)の最初の例の何が問題になっていますか?私には十分にシンプルに思える...
maerics 2012年

1
こんにちは、少し遅いですが、将来の誰でも、nodejsでsocketioを使用するための優れたチュートリアルを見つけることができます。programmerblog.net/using-socketio-with-nodejs
Jason W

回答:


154

編集: Socket.IOの開始ページにある優れたチャットの例を参考にした方がいいと思います。この回答を提供して以来、APIはかなり単純化されています。そうは言っても、新しいAPIのために元の答えがsmall-smallに更新されています。

今日はいい気分だから:

index.html

<!doctype html>
<html>
    <head>
        <script src='/socket.io/socket.io.js'></script>
        <script>
            var socket = io();

            socket.on('welcome', function(data) {
                addMessage(data.message);

                // Respond with a message including this clients' id sent from the server
                socket.emit('i am client', {data: 'foo!', id: data.id});
            });
            socket.on('time', function(data) {
                addMessage(data.time);
            });
            socket.on('error', console.error.bind(console));
            socket.on('message', console.log.bind(console));

            function addMessage(message) {
                var text = document.createTextNode(message),
                    el = document.createElement('li'),
                    messages = document.getElementById('messages');

                el.appendChild(text);
                messages.appendChild(el);
            }
        </script>
    </head>
    <body>
        <ul id='messages'></ul>
    </body>
</html>

app.js

var http = require('http'),
    fs = require('fs'),
    // NEVER use a Sync function except at start-up!
    index = fs.readFileSync(__dirname + '/index.html');

// Send index.html to all requests
var app = http.createServer(function(req, res) {
    res.writeHead(200, {'Content-Type': 'text/html'});
    res.end(index);
});

// Socket.io server listens to our app
var io = require('socket.io').listen(app);

// Send current time to all connected clients
function sendTime() {
    io.emit('time', { time: new Date().toJSON() });
}

// Send current time every 10 secs
setInterval(sendTime, 10000);

// Emit welcome message on connection
io.on('connection', function(socket) {
    // Use socket to communicate with this particular client only, sending it it's own id
    socket.emit('welcome', { message: 'Welcome!', id: socket.id });

    socket.on('i am client', console.log);
});

app.listen(3000);

おかげで、これはもちろん動作し、さらに重要なことに、これがどのように動作するかを理解し始めています。これを書いてくれて本当にありがとう。私は正直に、これをすべて機能させるために少なくとも3〜4時間は費やしました。どうもありがとうLinus!
Cocorico

これは私にはうまくいきません。ブラウザで空白のページが表示されます。サーバー側には、「クライアント承認済み」と「ハンドシェイク承認済み」以外の出力はありません。
ボリス

1
@Borisでは、index.htmlファイルをローカルで開いた場合に問題が発生する可能性があります。実行した場合は、スクリプトタグをsrc = "http://で置き換えます。Webサーバーでホストしている場合は、JavaScriptコンソールを開いて、何が失敗しているのかを特定します
CodeMonkeyKing

4
最初は「io not defined」と表示されます-代わりにこれを使用しました<script src = " cdn.socket.io/socket.io-1.2.1.js "> </script >と機能します
Alexander Mills

"npm init"を実行してから、npm "npm install socket.io --save"を介してソケットioをインストールする必要があります
Farid Movsumov

31

これが私の提出です!

このコードをhello.jsというファイルに入れ、ノードhello.jsを使用して実行すると、メッセージhelloが出力され、2つのソケットを介して送信されます。

このコードは、// Mirrorというラベルのコードセクションを介してクライアントからサーバーにバウンスされたhelloメッセージの変数を処理する方法を示しています。

変数名は、コメントの間の各セクションでのみ使用されるため、すべてではなくローカルで宣言されます。これらはそれぞれ別のファイルにあり、独自のノードとして実行できます。

// Server
var io1 = require('socket.io').listen(8321);

io1.on('connection', function(socket1) {
  socket1.on('bar', function(msg1) {
    console.log(msg1);
  });
});

// Mirror
var ioIn = require('socket.io').listen(8123);
var ioOut = require('socket.io-client');
var socketOut = ioOut.connect('http://localhost:8321');


ioIn.on('connection', function(socketIn) {
  socketIn.on('foo', function(msg) {
    socketOut.emit('bar', msg);
  });
});

// Client
var io2 = require('socket.io-client');
var socket2 = io2.connect('http://localhost:8123');

var msg2 = "hello";
socket2.emit('foo', msg2);


私はこれが受け入れられる解決策であるべきだと思います。少なくとも私を助けました。
Daft Fox

21

多分これはあなたにも役立つかもしれません。socket.ioがどのように機能するか頭を悩ませるのに苦労していたので、できる限りサンプルを煮詰めようとしました。

私はここに投稿された例からこの例を採用しました:http : //socket.io/get-started/chat/

まず、空のディレクトリから始めて、package.jsonという非常に単純なファイルを作成します。その中に以下を配置します。

{
"dependencies": {}
}

次に、コマンドラインでnpmを使用して、この例に必要な依存関係をインストールします

$ npm install --save express socket.io

ネットワーク接続/ CPUなどの速度によっては、この処理に数分かかる場合があります。すべてが計画どおりに進んだことを確認するには、package.jsonファイルをもう一度確認します。

$ cat package.json
{
  "dependencies": {
    "express": "~4.9.8",
    "socket.io": "~1.1.0"
  }
}

server.jsというファイルを作成します。 これは明らかにノードによって実行されるサーバーです。その中に次のコードを配置します。

var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http);

app.get('/', function(req, res){

  //send the index.html file for all requests
  res.sendFile(__dirname + '/index.html');

});

http.listen(3001, function(){

  console.log('listening on *:3001');

});

//for testing, we're just going to send data to the client every second
setInterval( function() {

  /*
    our message we want to send to the client: in this case it's just a random
    number that we generate on the server
  */
  var msg = Math.random();
  io.emit('message', msg);
  console.log (msg);

}, 1000);

index.htmlという最後のファイルを作成し、次のコードをその中に配置します。

<html>
<head></head>

<body>
  <div id="message"></div>

  <script src="/socket.io/socket.io.js"></script>
  <script>
    var socket = io();

    socket.on('message', function(msg){
      console.log(msg);
      document.getElementById("message").innerHTML = msg;
    });
  </script>
</body>
</html>

これで、この非常に単純な例をテストして、次のような出力を確認できます。

$ node server.js
listening on *:3001
0.9575486415997148
0.7801907607354224
0.665313188219443
0.8101786421611905
0.890920243691653

Webブラウザーを開いて、ノードプロセスを実行しているホスト名をポイントすると、ブラウザーに同じ番号が表示され、同じページを閲覧している他の接続されたブラウザーも表示されます。


10

私はこの投稿が数年前のものであることを理解していますが、私などの認定された初心者は、絶対的に最も単純な形に完全に削られた実用的な例を必要とする場合があります。

単純なすべてのsocket.ioの例で、関連するhttp.createServer()を見つけることができます。しかし、既存のWebページに少しのsocket.ioマジックを含めたい場合はどうでしょうか。ここに私が思いつくことができる絶対的に簡単で最小の例があります。

これは、コンソールから渡された文字列を大文字で返すだけです。

app.js

var http = require('http');

var app = http.createServer(function(req, res) {
        console.log('createServer');
});
app.listen(3000);

var io = require('socket.io').listen(app);


io.on('connection', function(socket) {
    io.emit('Server 2 Client Message', 'Welcome!' );

    socket.on('Client 2 Server Message', function(message)      {
        console.log(message);
        io.emit('Server 2 Client Message', message.toUpperCase() );     //upcase it
    });

});

index.html:

<!doctype html>
<html>
    <head>
        <script type='text/javascript' src='http://localhost:3000/socket.io/socket.io.js'></script>
        <script type='text/javascript'>
                var socket = io.connect(':3000');
                 // optionally use io('http://localhost:3000');
                 // but make *SURE* it matches the jScript src
                socket.on ('Server 2 Client Message',
                     function(messageFromServer)       {
                        console.log ('server said: ' + messageFromServer);
                     });

        </script>
    </head>
    <body>
        <h5>Worlds smallest Socket.io example to uppercase strings</h5>
        <p>
        <a href='#' onClick="javascript:socket.emit('Client 2 Server Message', 'return UPPERCASED in the console');">return UPPERCASED in the console</a>
                <br />
                socket.emit('Client 2 Server Message', 'try cut/paste this command in your console!');
        </p>
    </body>
</html>

走る:

npm init;  // accept defaults
npm  install  socket.io  http  --save ;
node app.js  &

このポートテストのようなものを使用して、ポートが開いていることを確認します。

ここでhttp://localhost/index.htmlを参照し、ブラウザコンソールを使用してメッセージをサーバーに送り返します。

おそらく、http.createServerを使用すると、次の2行が変更されます。

<script type='text/javascript' src='/socket.io/socket.io.js'></script>
var socket = io();

この非常に単純な例が、私の仲間の初心者が多少の苦労を免れることを願っています。ソケット定義に「予約語」のようなユーザー定義の変数名を使用しないように注意してください。


3
every simple socket.io example i could find involved http.createServer(). but what if you want to include a bit of socket.io magic in an existing webpageはいMHM ... var app = http.createServer(- WUT
ドン・チードル

1
とても役に立った、あなたは私の日を救った。どうもありがとう。これは、node.jsに負荷をかけすぎない最も簡単な答えです。この例は、すべての初心者がキックスタートしてノードに慣れるのに適しています。もう一度ありがとう
Karthik Elumalai

0

index.html

<!doctype html>
<html>
  <head>
    <title>Socket.IO chat</title>
    <style>
      * { margin: 0; padding: 0; box-sizing: border-box; }
      body { font: 13px Helvetica, Arial; }
      form { background: #000; padding: 3px; position: fixed; bottom: 0; width: 100%; }
      form input { border: 0; padding: 10px; width: 90%; margin-right: .5%; }
      form button { width: 9%; background: rgb(130, 224, 255); border: none; padding: 10px; }
      #messages { list-style-type: none; margin: 0; padding: 0; }
      #messages li { padding: 5px 10px; }
      #messages li:nth-child(odd) { background: #eee; }
      #messages { margin-bottom: 40px }
    </style>
  </head>
  <body>
    <ul id="messages"></ul>
    <form action="">
      <input id="m" autocomplete="off" /><button>Send</button>
    </form>
    <script src="https://cdn.socket.io/socket.io-1.2.0.js"></script>
    <script src="https://code.jquery.com/jquery-1.11.1.js"></script>
    <script>
      $(function () {
        var socket = io();
        $('form').submit(function(){
          socket.emit('chat message', $('#m').val());
          $('#m').val('');
          return false;
        });
        socket.on('chat message', function(msg){
          $('#messages').append($('<li>').text(msg));
          window.scrollTo(0, document.body.scrollHeight);
        });
      });
    </script>
  </body>
</html>

index.js

var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http);
var port = process.env.PORT || 3000;

app.get('/', function(req, res){
  res.sendFile(__dirname + '/index.html');
});

io.on('connection', function(socket){
  socket.on('chat message', function(msg){
    io.emit('chat message', msg);
  });
});

http.listen(port, function(){
  console.log('listening on *:' + port);
});

そして、これらのコマンドを実行してアプリケーションを実行します。

npm init;  // accept defaults
npm  install  socket.io  http  --save ;
node start

URLを開きます:- http://127.0.0.1:3000/ポートは異なる場合があります。この出力が表示されます

ここに画像の説明を入力してください

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.