美文网首页nodejs
04、NodeJS-文件操作&网络操作

04、NodeJS-文件操作&网络操作

作者: EndEvent | 来源:发表于2017-07-07 09:08 被阅读75次

    NodeJS: https://github.com/nodejs/node/ 在github中想要查找某个文件,按t;
    例如: 在使用fs.createWriteStream时,文档中没有具体方法,就可以通过查看源码,通过源码找对应的构造函数看有哪些属性设置,查看原型有哪些方法可用;

    npm中管理的包
    $ npm ls // 该方式不方便查看(有太多子集)
    $ npm ls --depth 0 // 即依赖子集为0
    $ npm ls --depth 1 // 即依赖子集的第一层

    nodemon:监视您的node.js应用程序的任何更改并自动重新启动服务器
    $ npm install -g nodemon
    $ nodemon xxx.js // 运行对应文件即可

    一、文件监视

    • fs.watchFile(filename[, options], listener(curr,prev))
      //  { persistent: true, interval: 5007 },即表示持续不断监视,时间间隔为5007毫秒
      options:{persistent,interval}
    
      const target = path.join(__dirname, process.argv[2]);
      fs.watchFile(target, (curr, prev)=>{
          console.log(`curr:${curr.size}; prev: ${prev.size}`);
    });
    
     思路:
     - 利用fs模块的文件监视功能监视指定MD文件
     - 当文件发生变化后,借助marked包提供的markdown to html功能将改变后的MD文件转换为HTML
     - 将得到的HTML替换到模版中(html = template.replace('{{content}}', html).replace('{{style}}', css);)
     - 利用BrowserSync模块实现浏览器自动刷新 
    
     markdown的样式有很多可以选择,选取的不同,html结构也会有所不同。
    关于github.css主体内容是包裹在div为.vs中:
    <body>
        <div class='vs'>{{content}}</div>
    </body>
    
      BrowserSync模块的使用
        1、$ npm install browser-sync // 安装browser-sync
        2、const browserSync = require("browser-sync");  // 导入模块
        3、通过browserSync创建一个文件服务器
        browserSync({
                server: path.dirname(target),  // 文件服务器的目录
                index:indexName // 在开启服务器之后会打开页面,该页面作为网站根目录
        });
        4、当文件修改后,刷新浏览器页面
        browserSync.reload(indexName);  // fileName是完整路径
    

    添加完BrowserSync后,就会在对应目录创建并启动一个服务器,自动打开页面(或手动打开,命令行有提示)http://192.168.1.112:3000 此时是在根目录下,也可以具体访问某个文件http://192.168.1.112:3000/xxx.html

    二、文件流

    • 什么是流?
      - 流是程序输入或输出的一个连续的字节序列
      - 文件流、网络流
      - 设备(例如鼠标、键盘、磁盘、屏幕、调制解调器和打印机)的输入和输出都是用流来处理的
    
    • 文件流
      - 文件流就是以面向对象的概念对文件数据进行的抽象
      - 文件流定义了一些对文件数据的操作方式
    
    • Node中的流操作
      • fs.createReadStream() 可读流
      读取流常用 API
      Event:data、end、error
      Method: read([size])、pause()、isPause()、resume()、
    setEncoding(encoding)、pipe(destination[, options])、unpipe([destination])
    
    • fs.createWriteStream() 可写流
      Event: error、pipe
      Method:write(chunk[, encoding][, callback])、end([chunk][, encoding][, callback])、setDefaultEncoding(encoding)
    

    案例: 拷贝文件功能

    fs-extra文件操作模块 可以是拷贝、删除、创建等操作

    三、网络操作

    • NET模块
      在Node中socket通信的一种实现
        let server = net.createServer( (socket) => {  // 当客户端链接时,即会触发
     
        // client有三个参数: 端口号、IPV4/IPV6、ip
        var client = socket.address();
        // 或直接通过socket.remoteAddress / socket.remotePort 访问到
    
        // 监听socket,网络流
        socket.on('data', (chunk)=>{
    
        });
      } );
    
      // 绑定IP, 监听2017端口
      const port = 2017;
      // server.listen(options[, callback])
      // options { host: '192.168.1.100', port: 80}
      server.listen(port, (err) => {
        
      });
      // 为了方便操作,命令行方式链接服务端(使用telnet操作): $ telnet 192.168.1.100 2017
    
      // 简便写法
      // port 端口号, host IP地址
      // net.createServer(socketConneted).listen(port,  host, (err) => { });
      net.createServer(socketConneted).listen({port:port, host: host}, (err) => { });
      function socketConneted(socket){ ... }
    
      // 创建链接
      const client = net.connect({port: '2017', host:'192.168.1.100'}, ()=>{
        console.log('链接服务器成功');
        client.write('hello ??');
    });
      
      // 监听到数据
      client.on('data', (chunk) => {
        console.log('接收到数据:' + chunk.toString());
    })
    
    telnet
    process.stdin.on('data', (chunk) => {
        // 转成string类型,并且去掉前后空白
        console.log(chunk.toString().trim());
    });
    

    案例:简易的聊天室

    查看文档是net(http和http是高度封装的,net中更多了解socket通信是怎么的一个过程,如何的一个操作)

    相关文章

      网友评论

        本文标题:04、NodeJS-文件操作&网络操作

        本文链接:https://www.haomeiwen.com/subject/vwfpqxtx.html