• Node中的net模块提供的前端通信

    • 客户端

      业务: 客户端现在要在终端输入内容,然后回车发送内容给服务器

      解决: Node中提供了一个叫做 readline 的 模块用于读取命令行内容 【 单行读取 】,readline适合动态交互式流处理,当流被创建时,readline只会监听新增的行而忽略已有的行。

        const net = require( 'net' )//第一步引入内置模块net
      const socket = net.Socket()//第二步创建客户端
      const host = 'localhost'//定义服务器的域名
      const port = 5000 //定义服务器的端口
      socket.connect( port,host, () => {
      socket.write( 'hello 我上线了' ) // 将一个信息发送给服务器
      })
      const rl = readline.createInterface({
       input: process.stdin,
       output: process.stdout
      });

      socket.on('data', msg => { // 客户端通过data事件展示信息,然后发送信息给服务器
       console.log( msg.toString() )
       say()
      })

      socket.on( 'error', ( error ) => { //处理错误报出
       console.log( 'error is : ' + error )
      })

      socket.on( 'close', () => { // 客户端正常下线
       console.log( `客户端下线了` )
      })

      function say () {
       rl.question('请输入:', ( answer ) => {
         if( answer === 'bye' ){
           //表示正常下线
           socket.destroy() // 客户端销毁
           rl.close()//读取命令行关闭
        }else{
           //表示正常聊天
           socket.write( answer )
        }
      });
      }
    • 服务器

        const net = require( 'net' ) //引入net模块,用于创建服务器/客户端

      const server = net.createServer() // 创建服务器

      const host = 'localhost' // 创建 域名  

      const port = 5000 // 创建端口

      let count = 0

      const clients = {}    //   数组? 对象?

      server.on('connection', ( client ) => { // 服务器通过connection事件连接客户端
       // client指的是每一个连接的客户端
       // client 是有多个 ,
       // 问题: client会错乱   解决: 起名   数字编号         计数
       client.name = ++count  // 计数,给每一个客户端起名
       clients[ client.name ] = client // 将每一个客户端放入clients中存储起来

       client.on( 'data', msg => { // 服务器通过data事件来接收客户端发来的信息
         // msg 就是客户端发来的信息 , msg这个信息是二进制
         console.log( `客户端${ client.name }说:${ msg.toString() }` )
         boardCaster( client,msg )
      })

       client.on( 'error', error => { // 服务器处理错误报出
         console.log( 'error is: ' + error )
      })

       client.on( 'close', () => { // 服务端接收客户端正常下线行为
         delete clients[ client.name ] // 从存储client的地方删除下线的客户端
         console.log( `客户端${ client.name }下线了` )
      })

      })

      // 我们需要将所有客户端发来的信息全部展示在服务器界面上【 聊天室 】 -》 广播

      // 广播就是将所有的客户端以及客户端发来的信息展示在服务端界面上

      function boardCaster ( client,msg ) { //广播的函数

       for( var key in clients ){
         // clients[ key ].write( `谁说了什么` ) // 写信息在服务端
         clients[ key ].write( `客户端${ client.name }说:${ msg.toString() }` ) // 写信息在服务端
      }

      }

      // 监听服务器
      server.listen( port,host,() => {
       console.log( `服务器运行在: http://${ host }:${ port }` )
      })

Node中的net模块提供的前端通信的更多相关文章

  1. 关于node中两个模块相互引用却不会死循环的问题

    关于node中两个模块相互引用却不会死循环的问题 node中是通过require来导入加载模块的,require有两个作用: 1.加载文件模块并执行里面的代码 2.拿到被加载文件模块导出的接口对象 现 ...

  2. node中的url模块解析结果

    1. URL模块作用: url 模块用于处理与解析 URL. 使用方法如下: const url = require('url'); 2. URL 字符串与 URL 对象 URL 字符串是结构化的字符 ...

  3. 说说对 Node 中的 fs 模块的理解? 有哪些常用方法?

    一.是什么 fs(file system),该模块提供本地文件的读写能力,基本上是POSIX文件操作命令的简单包装 可以说,所有与文件的操作都是通过fs核心模块实现 导入模块如下: const fs  ...

  4. Node中的http模块

    通过Node模块,我们可以实现客户端和服务器端.这篇文章主要研究如何利用http和一些相关模块构建客户端和服务器端代码.读完本文,将能够实现client向server发送数据,而server将数据原样 ...

  5. Node中require第三方模块的规则

    Node.js中使用CommonJs模块化机制,通过npm下载的第三方包,我们在项目中引入第三方包都是:let xx = require('第三方包名'),究竟require方法加载第三方包的原理机制 ...

  6. node中npm安装模块的网络问题

    最近使用node开发时,发现所有的依赖模块都安装不了啦,一直报错如下 rollbackFailedOptional: verb npm-session 5a4a66a1b8d06dc3 后来才发现是由 ...

  7. Node中使用mysql模块遇到的问题

    Node的mysql模块,本人的感受就是不好用,各种报错,各种坑,有一个问题困扰了我很久,也不知道是不是我使用的方式不对,不过后来用easymysql模块解决了,我才深信这是一个坑. 问题描述: 假设 ...

  8. node中的cluster模块开启进程,进程共享数据

    说明:共享数据 var collection = [41, 41, 41, 41] master.js console.log('###---start---###') var cluster = r ...

  9. node.js中使用http模块创建服务器和客户端

    node.js中的 http 模块提供了创建服务器和客户端的方法,http 全称是超文本传输协议,基于 tcp 之上,属于应用层协议. 一.创建http服务器 const http = require ...

随机推荐

  1. 重新学习微信小程序

    基础学习: 传送门:http://www.jianshu.com/p/1cec15a81722 这个简书博客介绍的很详细,今天思思重新学习了一下. 一路到最后只遇到一个坑,还是自己不仔细.这里记录下: ...

  2. 关于类似QQ的展开和折叠效果的实现

    介绍: 1.两级折叠与展开: 实现原理如下: 1>通过表视图的组的头视图和单元格实现; 2>通过改变cell的高度实现; 3>通过cell实现; 实现 UITableView 的ce ...

  3. Jupter Notebook常用快捷键与常用的魔法命令

    jupter notebook快捷键整理 Part1 1.删除Cell——双击D 2.撤销删除——Z 3.新建Cell——A/B (向上/向下) 4.命令窗口——P 5.运行——Ctrl+Enter ...

  4. tp5博客项目实战2

    改虚拟主机 (用www.tp5.com直接访问替代localhost/blog/tp5/public) 1.host修改 位置C:\Windows\System32\drivers\etc 127.0 ...

  5. 阿里云ECS服务器活动99元一年(2019年 Hi拼团,拼着买,更划算)

    2019年10月22日更新,阿里云推荐有礼活动:ECS突发性能T6-低至99元/年赶紧上车~ 低价高性能,拼着买更划算 点我参加活动>> 购买前领取阿里云幸运券,更有可能享受折上折的优惠. ...

  6. Linear regression with one variable - Cost function

    摘要: 本文是吴恩达 (Andrew Ng)老师<机器学习>课程,第二章<单变量线性回归>中第7课时<代价函数>的视频原文字幕.为本人在视频学习过程中逐字逐句记录下 ...

  7. git merge仓

    git merge --no-ff branch 合并指定代码 如果有冲突 git mergetool   可视化解决冲突, qa! 全退出 如果修复失败 git checkout branch -f ...

  8. canvas画箭头demo

    效果图: 代码: <!DOCTYPE html> <html> <title>canvas画箭头demo</title> <body> &l ...

  9. UIPath工具里面如何入力一览里面的数据

    问题描述: UIpath工具如何在网页里面入力一览多条的数据.例如:某个公司里面在自己的内部员工管理的软件里面手动入力公司员工的所有信息之后反馈到数据库当中. 解决方法: UIpath工具来入力数据, ...

  10. v-bind 绑定属性

    与mustache相区别,他是对内容(content内部)进行修改的.v-bind的语法糖写法是   : v-bind 动态绑定class属性:v-bind:class="对象名" ...