在B/S场景中,通常我们前端主动访问后端可以使用axios,效果很理想,而后端要访问前端则不能这样操作了,可以考虑SSE、websocket和gRPC等方式,实时和性能均有保障。
下面给出一个简单的例子,后端是node+express,前端是html+javascript(jquery+axios) 实现一个简单的web聊天室。
不说废话,直接上代码:
const stringRandom = require("string-random"); const express = require('express'); const app = express(); var msgs=[]; var clients=[]; app.use('/', express.static('./')); app.get('/events', (req,res)=>{ res.writeHead(200, { 'Content-Type': 'text/event-stream', 'Connection': 'keep-alive', 'Cache-Control': 'no-cache' }); res.write(`data: ${JSON.stringify(msgs)}\n\n`); let clientid=stringRandom(32, { letters: 'ABCDEF' }) clients.push({ "clientid":clientid, "res":res }); req.on('close', () => { clients = clients.filter(item => (item.clientid != clientid)); }); }); app.post('/sendmsg',express.json(), (req,res)=>{ msgs.push(req.body); res.json({"code":200}); clients.forEach(client=>{ client.res.write(`data: ${JSON.stringify(req.body)}\n\n`) }); }); app.listen(3000, () => { console.log(`极简聊天室服务启动`); })
极简聊天室
浏览器访问效果如下: