socket.io實現客戶端和服務端的雙向通訊

首先建立項目文件夾並初始化,安裝socket.io和expressjavascript

npm init && npm i -S socket.io express

用express建立後端服務,建立index.js:html

const express = require('express');
const http = require('http');
const fs = require('fs');
const path = require('path');
const socketIo = require('socket.io')

var app = express();
var server = http.Server(app);
var io = socketIo(server);

app.get('/', (req, res) => {
    var html = fs.readFileSync(path.resolve(__dirname, './index.html'), 'utf-8');
    res.send(html);
});



io.on('connection', socket => {
    socket.emit('hello', {
        message: 'message from server',
        time: (new Date()).toLocaleString()
    });
    socket.on('hi', res => {
        console.log(res);
    });
    // console.log('a user come ' + (new Date()).toLocaleString());
});

server.listen(3000, () => {
    console.log('server is listen on port 3000');
});

建立index.html,模擬客戶端:java

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <script src="/socket.io/socket.io.js"></script>
</head>
<body>
    <p>hello world</p>
    <script>
        var socket = io();
        socket.on('hello', res => {
            console.log(res);
        });
        socket.emit('hi', {
            message: 'message from client',
            time: (new Date()).toLocaleString()
        })
    </script>
</body>
</html>

項目文件夾:node

而後用node啓動服務端:express

node index.js

或者在package.json中寫啓動腳本npm

{
  "name": "chat",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1",
    "dev": "node index.js"
  },
  "author": "",
  "license": "ISC",
  "dependencies": {
    "express": "^4.16.3",
    "socket.io": "^2.1.1"
  }
}

而後執行json

npm run dev

成功啓動後端服務,打開本地 localhost:3000 ,便可獲取信息:後端

相關文章
相關標籤/搜索