首页 > web前端 > js教程 > node.js创建简单聊天室的方法介绍

node.js创建简单聊天室的方法介绍

青灯夜游
发布: 2021-02-01 11:24:07
转载
3044 人浏览过

使用nodejs如何创建一个简单聊天室?下面本篇文章给大家介绍一下。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

node.js创建简单聊天室的方法介绍

相关推荐:《nodejs视频教程

刚刚开始学js,本文是基于node.js和websocket实现一个简单的在线聊天室系统(聊天群)。

本文适合纯小白阅读。

废话不多说,我们正式开始。

在B/S架构中,我们要得到一个数据,要向服务器请求,然后服务器响应。那么如果我们客户端不发送请求,服务器会不会主动给我们的客户端(浏览器)发东西呢?

答案是不会的,客户端和服务器通过TCP/IP协议进行连接,然后通过HTTP协议进行请求连接。而HTTP协议是一个请求—响应式的协议,而且它是一个无状态的协议,即每一次请求—响应之间是没有关系的。

而我们的聊天室需要什么呢?

1.发送消息      2.接收消息

在接收消息中:一个客户端给服务器发送消息,服务器接收消息,然后主动发给另一个客户端。

所以HTTP满足不了我们的要求。这里我们就要用到socket协议。当服务器与客户端连接后,两者都会时刻做着收发消息的准备。

首先在npm中下载socket.io模块(之前要安装了node.js才行)。打开cmd。

(我创建了一个node.js chat文件夹,文件都放在这里面)

然后开始写我们的服务器代码,创建文件server.js。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

//server.js

 

var http = require('http');

var fs = require('fs');

var ws = require('socket.io'); //引入socket.io

 

var server = http.createServer(function (req, res) {

    var html = fs.readFileSync('./client.html');

   //client.html是发送给客户端的文件(客户端界面)

 

    res.end(html);

}).listen(8000);

 

var io = ws(server); //http服务与ws服务相关联, 返回io服务实例

 

//监听用户的连接事件

io.on('connection',function (socket) {     

    //发生在用户连接io服务器时

    console.log('有新用户进入房间');

 

    //消息发送事件

    socket.on('message',function (obj) {

       console.log(obj);

       io.emit('message',obj); //发送消息给所有客户端(广播)

    });

});

登录后复制

然后开始写客户端。

因为我们服务器用的是socket.io,所以在客户端中应该使用socket.io相对应的服务。此处我直接引入了一个js文件。

创建文件client.html。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

//client.html

 

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="UTF-8">

    <title>Node.js+webSocket聊天室</title>

</head>

<body>

<h1>liky聊天室</h1>

<textarea name="" id="text" ></textarea>

<button id="btn">发送</button>

 

<script src="http://wulv5.com/js/socket.io.min.js"></script>

<script>

    var socket = io.connect("/"); //连接聊天室的io服务器 io服务器的根地址

 

    var oText = document.getElementById("text");

    var oBtn = document.getElementById("btn");

 

    var myMessage = "";

 

    oBtn.onclick = function () {

        var mes = oText.value;

 

        //当消息为空时

        if(!mes){

            return;

        }

        myMessage = mes;

        socket.send(mes); //发送消息到服务器

        oText.value = ""; //清空文本框

    }

 

    //当服务器广播消息时,触发message事件,消息内容在回调函数中

    socket.on(&#39;message&#39;,function (mm) {

        var p = document.createElement(&#39;p&#39;);

        p.innerText = mm;

        if(myMessage === mm){

            p.style.cssText = "color:red;margin-left:10%";

        }

        document.body.appendChild(p);

    })

 

</script>

</body>

</html>

登录后复制

到此,代码部分就完成了。接下来打开cmd,运行我们的文件。

现在就可以打开浏览器看一下效果啦。打开浏览器,访问地址http://localhost:8000/。多打开几个页面来试试效果。

这样,一个简单的本地聊天室就完成啦。可以传到服务器上,就可以和别人一起聊天啦(这个有空我再写一下)。

更多编程相关知识,请访问:编程教学!!

以上是node.js创建简单聊天室的方法介绍的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板