基于Node.js,Express,Socket.io创建简单聊天室

基于Node.js,Express,Socket.io创建简单聊天室

首先看服务器端:
//创建express服务器(注意:创建express服务器,需要http模块的支持)
var express = require('express');
var app = express();
var server = require('http').createServer(app);
var port = process.env.PORT || 3030;
server.listen(port, function () {
  console.log('server listening at port %d', port);
});
//创建路由规则,客户端连接时(即打开http://127.0.0.1:3000/index.html),发送消息给客户端
app.use(express.static(__dirname + '/public'));//定义静态文件目录

//将socket.io绑定到express服务器
var io = require('socket.io').listen(server);
var namelist = [];//用于存储昵称
//给socket.io添加客户端连接服务器监听事件
io.on('connection', function (socket) {
  console.log('user connected');//输出客户端连接服务器日志
  socket.emit('welcome', {text: 'connected'});//发送消息给新连接服务器的客户端

  //服务器监听客户端提交的昵称,并判断是否已经存在
  socket.on('name', function (data, callback) {
    if (namelist.indexOf(data) === -1) {//昵称不存在
      callback(true);//从服务器返回给客户端的回调函数,昵称不存在返回true
      namelist.push(data);//存储新添加的昵称
      socket.uname = data;//用于断开连接时,从列表时删除
      console.log('昵称:' + namelist);
      io.sockets.emit('usernames', namelist);//把昵称列表广播给所有在线的用户
    }
    else {
      callback(false);//昵称存在,返回客户端为false
    }

  });
  //当有客户端断开连接时,重新发送昵称列表给所有在线客户端,实现实时更新
  socket.on('disconnect', function () {
    if (!socket.uname) return;
    if (namelist.indexOf(socket.uname) > -1) {//从在线列表删除断开连接的客户昵称
      namelist.splice(namelist.indexOf(socket.uname), 1);//数组中删除元素
    }
    console.log('昵称:' + namelist);
    io.sockets.emit('usernames', namelist);//把昵称列表广播给所有在线的用户
  });
  //服务器监听客户端发送的消息,并把消息广播给所有连接服务器的客户端
  socket.on('message', function (data) {
    io.sockets.emit('sendmessage', {senduser: socket.uname, message: data});
  });
});
页面逻辑处理:
var socket = io.connect('http://127.0.0.1:3030');//连接服务器
socket.on('welcome', function (data) {//监听事件,获取服务器发送的消息
    console.log(data.text);//输出消息
});
var doc = document,
    uname = doc.getElementById('uname'),
    addname = doc.getElementById('addname'),
    list = doc.getElementById('namelist'),
    message = doc.getElementById('message'),
    sendmessage = doc.getElementById('addmessage'),
    showmessage = doc.getElementById('show');
//提交表单,将昵称发送到服务器
addname.onsubmit = function () {
    if (uname.value === "") {
        alert("昵称不能为空!");
        return false;
    }
    socket.emit('name', uname.value, function (data) {//在服务器接收消息之后,接收来自服务器端的数据
        if (data) {//昵称不存在列表中,昵称添加成功
            console.log('successfully');//设置昵称成功
            addname.style.display = "none";//隐藏添加昵称表单
            sendmessage.style.display = "block";//显示发送消息表单
        }
        else {//昵称存在于列表
            alert('昵称已存在');
        }
    });
    return false;//阻止提交表单
};
//接收服务器广播的昵称列表,并显示在页面上
socket.on('usernames', function (data) {
    var html = '';
    for (var i = 0; i < data.length; i++) {
        html += '<li>' + data[i] + '</li>';
    }
    list.innerHTML = html;
});
//提交表单,将消息发送给服务器
sendmessage.onsubmit = function () {
    if (message.value === "") {
        alert("消息不能为空!");

    } else {
        socket.emit('message', message.value);
        message.value = "";//清空文本框

    }
    return false;//阻止提交表单
};
//接收服务器发送的客户端发送的消息,并显示在界面
socket.on('sendmessage', function (data) {
    var elem = doc.createElement('p');
    var txt = doc.createTextNode(data.senduser + ':' + data.message);
    elem.appendChild(txt);
    showmessage.appendChild(elem);
});
主页html:
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>使用socket.io和express创建一个聊天工具</title>
     <link rel="stylesheet" href="style.css"/>
    <style>

    </style>
</head>
<body>
<div id="content">
    <div id="show"></div>
    <div id="showlist">
        <ul id="namelist"></ul>
    </div>
    <div id="clear"></div>
    <form action="#" id="addname">
        <label for="uname">昵称:</label>
        <input type="text" id="uname" class="input"/>
        <input type="submit" value="添加昵称" class="btn"/>
    </form>
    <form action="#" id="addmessage">
        <label for="message">消息:</label>
        <input type="text" id="message" class="input"/>
        <input type="submit" value="发送消息" class="btn"/>
    </form>
</div>
<!--如果客户端和服务器在同一服务器上,将会自动提供socket.io客户端的库-->
<script src="/socket.io/socket.io.js"></script>
<script src="main.js"></script>
</body>
</html>
css:
* {
    margin: 0;
    padding: 0;
    font-family: "Microsoft YaHei UI";
    font-size: medium;
}

#content {
    width: 80%;
    height: 500px;
    margin: 20px auto;
    background-color: aliceblue;
    border-radius: 10px;
    padding: 20px;
    border: 1px dashed black;
    position: relative;
}

#show {
    float: left;
    width: 50%;
    height: 400px;
    border: 1px solid black;
}

#showlist {
    overflow: hidden;
    padding-left: 40px;
}

#clear {
    clear: both;
}

#addmessage {
    display: none;
}

#addmessage, #addname {
    width: 100%;
    text-align: center;
    position: absolute;
    bottom: 30px;
}

.input, .btn {
    height: 30px;
    border: none;
    border-radius: 3px;
}

.input {
    width: 300px;
}

.btn {
    width: 100px;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,要使用Node.jsSocket.io搭建一个基本的聊天室,可以参考以下步骤: 1. 安装Node.js和npm 2. 创建一个新的Node.js项目并在项目文件夹里打开命令行 3. 在命令行中输入以下命令来安装Socket.io: ``` npm install socket.io ``` 4. 创建一个新的文件夹用于存放服务器端代码,我们称之为“server” 5. 在“server”文件夹中创建一个新的JavaScript文件,例如“server.js” 6. 在“server.js”中添加以下代码: ``` const io = require('socket.io')(); io.on('connection', (socket) => { console.log('a user connected'); socket.on('disconnect', () => { console.log('user disconnected'); }); }); io.listen(3000); ``` 7. 在命令行中进入“server”文件夹并运行“server.js”文件: ``` node server.js ``` 8. 创建一个新的文件夹用于存放客户端代码,我们称之为“client” 9. 在“client”文件夹中创建一个新的HTML文件,例如“index.html” 10. 在“index.html”中添加以下代码: ``` <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Socket.io Chat Room</title> </head> <body> <h1>Socket.io Chat Room</h1> <div id="messages"></div> <form id="message-form"> <input type="text" id="input-message" placeholder="Type your message here..."> <button type="submit">Send</button> </form> <script src="https://cdn.socket.io/socket.io-3.0.1.min.js"></script> <script src="client.js"></script> </body> </html> ``` 11. 在“client”文件夹中创建一个新的JavaScript文件,例如“client.js” 12. 在“client.js”中添加以下代码: ``` const socket = io('http://localhost:3000'); const messageForm = document.getElementById('message-form'); const inputMessage = document.getElementById('input-message'); const messages = document.getElementById('messages'); messageForm.addEventListener('submit', (event) => { event.preventDefault(); const message = inputMessage.value; if (message) { socket.emit('chat message', message); inputMessage.value = ''; } }); socket.on('chat message', (message) => { const li = document.createElement('li'); li.textContent = message; messages.appendChild(li); }); ``` 13. 在命令行中进入“client”文件夹并运行以下命令: ``` npm install express ``` 14. 在“client”文件夹中创建一个新的JavaScript文件,例如“server.js” 15. 在“server.js”中添加以下代码: ``` const express = require('express'); const app = express(); app.use(express.static('public')); app.listen(8080, () => { console.log('Server running on http://localhost:8080'); }); ``` 16. 在命令行中进入“client”文件夹并运行以下命令: ``` node server.js ``` 现在你就可以在浏览器中打开“http://localhost:8080”并开始聊天了。 要实现私聊和创建群聊的功能,你需要在服务器端和客户端中添加一些额外的代码。 对于私聊功能,你可以创建一个“私聊房间”,只有被邀请的用户才能加入该房间,并在该房间中进行私人对话。以下是一些可能有用的代码: 1. 服务器端: ``` const users = {}; io.on('connection', (socket) => { console.log('a user connected'); socket.on('login', (username) => { users[username] = socket.id; console.log(`${username} logged in`); }); socket.on('invite', (username) => { const roomId = `${socket.id}:${users[username]}`; socket.join(roomId); io.to(users[username]).emit('invited', roomId); }); socket.on('chat message', (data) => { const { message, roomId } = data; io.to(roomId).emit('chat message', message); }); socket.on('disconnect', () => { console.log('user disconnected'); }); }); ``` 2. 客户端: ``` const socket = io('http://localhost:3000'); const username = prompt('What is your name?'); socket.emit('login', username); let roomId = null; const inviteForm = document.getElementById('invite-form'); const inviteInput = document.getElementById('invite-input'); inviteForm.addEventListener('submit', (event) => { event.preventDefault(); const username = inviteInput.value; if (username) { socket.emit('invite', username); inviteInput.value = ''; } }); socket.on('invited', (id) => { roomId = id; messages.innerHTML = ''; messageForm.style.display = 'block'; }); messageForm.addEventListener('submit', (event) => { event.preventDefault(); const message = inputMessage.value; if (message) { socket.emit('chat message', { message, roomId }); inputMessage.value = ''; } }); socket.on('chat message', (message) => { const li = document.createElement('li'); li.textContent = message; messages.appendChild(li); }); ``` 对于创建群聊功能,你可以创建一个“群聊房间”,所有用户都可以加入该房间,并在该房间中进行群聊。以下是一些可能有用的代码: 1. 服务器端: ``` const rooms = {}; io.on('connection', (socket) => { console.log('a user connected'); socket.on('create room', () => { const roomId = socket.id; socket.join(roomId); rooms[roomId] = { name: `Room ${Object.keys(rooms).length + 1}` }; io.to(roomId).emit('room created', roomId); console.log(`Room ${roomId} created`); }); socket.on('join room', (roomId) => { socket.join(roomId); io.to(roomId).emit('user joined', { username: 'anonymous', message: 'joined the chat' }); console.log(`User ${socket.id} joined room ${roomId}`); }); socket.on('chat message', (data) => { const { message, roomId } = data; io.to(roomId).emit('chat message', message); }); socket.on('disconnect', () => { console.log('user disconnected'); }); }); ``` 2. 客户端: ``` const socket = io('http://localhost:3000'); const createRoomButton = document.getElementById('create-room-button'); const joinRoomForm = document.getElementById('join-room-form'); const joinRoomInput = document.getElementById('join-room-input'); createRoomButton.addEventListener('click', () => { socket.emit('create room'); }); joinRoomForm.addEventListener('submit', (event) => { event.preventDefault(); const roomId = joinRoomInput.value; if (roomId) { socket.emit('join room', roomId); joinRoomInput.value = ''; messages.innerHTML = ''; messageForm.style.display = 'block'; } }); socket.on('room created', (roomId) => { const option = document.createElement('option'); option.value = roomId; option.textContent = `Room ${Object.keys(rooms).length}`; selectRoom.appendChild(option); }); socket.on('user joined', (data) => { const { username, message } = data; const li = document.createElement('li'); li.textContent = `${username} ${message}`; messages.appendChild(li); }); socket.on('chat message', (message) => { const li = document.createElement('li'); li.textContent = message; messages.appendChild(li); }); ``` 以上代码只是一个简单的示例,你可以根据自己的需求进行更改和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值