• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >JavaScript > Node.js制作简单聊天室

Node.js制作简单聊天室

作者:光明大神棍 字体:[增加 减小] 来源:互联网 时间:2017-05-11

光明大神棍通过本文主要向大家介绍了node.js聊天室,node.js聊天,node.js即时聊天,node.js,node.js下载等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

看了TCP的有关知识,写了个基于NET的聊天室。

var net = require('net');

var count = 0,
  users = {};

var server = net.createServer(function (conn) {
  console.log('连接到');
  conn.write(
     "\r\n > welcome to node-chat!"
    + "\r\n > " + count + " other people are connected at this time."
    + "\r\n > please write your name and press enter: "
   );
  count++;
  // 代表当前连接的昵称
  var nickname;
  console.log(conn);
  conn.on('data', function (data) {
    // 删除\r\n
    // data = data.replace('\r\n', '  ');

    // 当前注册的昵称不存在
    if (!nickname) {
      // 用户名存在
      if(users[data]) {
        conn.write('nickname in use');
        return;
      } else {
        // 用户名给nickname
        nickname = data;
        users[nickname] = conn;
        for (var i in users) {
          users[i].write('\r\n > ' + nickname + ' join our room \r\n > I: ');
        }
      }
    } else {
      // 开始聊天
      for (var i in users) {
        if (i != nickname) {
          users[i].write('\r\n > ' + nickname + ': ' + data);

        }
      }
    } 
  });

  conn.on('close', function () {
    count--;
  });
  conn.setEncoding('utf8');


});

server.listen(3000, function () {
  console.log('服务器监听端口3000');
})
</div>

运行截图:

终端:

telnet 这里截取了两个网友

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • Node.js制作简单聊天室

相关文章

  • 2017-05-11js中Number数字数值运算后值不对的解决方法
  • 2017-05-11微信小程序page的生命周期和音频播放及监听实例详解
  • 2017-05-11JavaScript实现弹窗效果代码分析
  • 2017-05-11完美解决UI-Grid表格元素中多个空格显示为一个空格的问题
  • 2017-05-11详解微信小程序开发之城市选择器 城市切换
  • 2017-05-11BootStrap实现鼠标悬停下拉列表功能
  • 2017-05-11Cookies 和 Session的详解及区别
  • 2017-05-11原生JS轮播图插件
  • 2017-05-11纯原生js实现table表格的增删
  • 2017-05-11浅析vue数据绑定

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • ajax详解
    • bootstrap为水平排列的表单和内联表单设置可选的图标
    • 提高Web性能的前端优化技巧总结
    • JS实现获取图片大小和预览的方法完整实例【兼容IE和其它浏览器】
    • js 性能优化之快速响应的用户界面
    • nodejs中使用HTTP分块响应和定时器示例代码
    • 浅谈angular2的http请求返回结果的subcribe注意事项
    • 基于JS实现bookstore静态页面的实例代码
    • Vue.js父与子组件之间传参示例
    • jQuery插件FusionCharts实现的2D柱状图效果示例【附demo源码下载】

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有