聊天室入门实战(node,socket.io实现)--第一章(实现登录群聊功能)

项目已经部署,请访问 : "chat.mycollagelife.com"

这几天花时间写了一个聊天室的demo,实现了登录,用户名检测,群聊,单聊,图片发送等功能,这个系列博客会分为几章讲解,由浅入深,逐步优化,章节间关联性较大,建议从第一章开始阅读。由于水平有限,有说的不对的地方还请各位大佬们留言指正。有不清楚的地方也可以留言提问。该博客说的非常基础,请耐心看完

下面我贴几张完成后的项目图片:

登录界面:


登录检查:


群聊界面:



私聊界面:


该项目已经上传至Github   https://github.com/neuqzxy/chat  觉得可以的话给个星星吧吐舌头现在github上有original文件夹是我已经完成的项目,我会将这个系列博客写完后的项目也上传供大家参考。(注意一点的是,我已经完成的项目是用了ejs模板引擎,其实一点用处都没有,大家可以把chat.ejs当做chat.html,修改一下引用的js的路径就行了)



第一天 -- 实现简单的登录和群聊功能

这一章我们需要具备的能力有(具有jquery的简单操作,node以及express的简单操作,socket.io的大致了解的能力)在本章我也会尽量详细的讲解。如果只是想做前端或后台的功能,大家完全可以拷贝自己不做的那一部分。所以不会node的同学不用太担心。

先看看我们将要实现的样式吧


自己发的消息是蓝色的,别人的消息是红色的



好了下面我们开始我们的项目了


node.js环境配置

开始项目前必须要保证你的电脑已经安装好了node环境。win用户直接去node.js官网下载安装包即可安装,和QQ安装没什么差别,Mac和Linux用户如果想源码包安装的话也可

以参考我的这篇文章《ubuntu下配置node环境》。 安装好后输入

node -v
npm -v
应该可以看到版本号的。否则安装失败了。


先写简单demo出来

1. 新建一个文件夹叫 chat

2. 在终端输入 npm init  然后一直回车,他会自动给你生成一个package.json文件

3. 创建如下文件夹


之前说过,original项目中使用的是ejs引擎,这个项目中我只用HTML文件,这里main.js是前端js,app.js是node.js。

4. 下面我们安装express和socket.io,输入:

npm install express --save
npm install socket.io --save
这时发现多了一个node_modules文件夹,这是装第三方模块的文件夹,express就在里面,我们不用管这个文件夹

5. 打开socket.io官网,找到这么一段:






5.1 我们先写一个服务器运行一下,在app.js里写:

/**
 * Created by zhouxinyu on 2017/8/6.
 */
const express = require('express');  // const是ES6的语法,代表常量,准确来说就是指向不发生改变。如果不习惯就用var代替
const app = express();               // express官网就是这么写的就是用来创建一个express程序,赋值给app。如果不理解就当公式记住
const fs = require('fs');            // 这个是node的文件读取模块,用于读取文件
const path = require('path');        // 这是node的路径处理模块,可以格式化路径
app.listen(3000,()=>{                // ()=>是箭头函数,ES6语法,如果不习惯可以使用 function() 来代替 ()=>
    console.log("server running at 127.0.0.1:3000");       // 代表监听3000端口,然后执行回调函数在控制台输出。
});

/**
 * app.get(): express中的一个中间件,用于匹配get请求,所谓中间件就是在该轮http请求中依次执行的一系列函数。
 * '/': 它匹配get请求的根路由 '/'也就是 127.0.0.1:3000/就匹配到他了
 * (req,res): ES6语法的箭头函数,你暂时可以理解为function(req,res){}。
 * req带表浏览器的请求对象,res代表服务器的返回对象
 */
app.get('/',(req,res)=>{
    res.redirect('/chat.html');       // express的重定向函数。如果浏览器请求了根路由'/',浏览器就给他重定向到 '127.0.0.1:3000/chat.html'路由中
});


/**
 * 怕不理解,这里我使用的是ES5的语法,没有用到箭头函数
 * 这里匹配到的是/chat.html就是上面重定向到的路径。
 */
app.get('/chat.html',function (req,res) {
    fs.readFile(path.join(__dirname,'./public/chat.html'),function(err,data){       //读取文件,readFile里传入的是文件路径和回调函数,这里用path.join()格式化了路径。
        if(err){
            console.error("读取chat.
  • 10
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
首先,要使用Node.js和Socket.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); }); ``` 以上代码只是一个简单的示例,你可以根据自己的需求进行更改和扩展。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值