首先建立項目文件夾並初始化,安裝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 ,便可獲取信息:後端