博客
关于我
Node.js的系统模块
阅读量:787 次
发布时间:2019-03-25

本文共 2442 字,大约阅读时间需要 8 分钟。

Node.js 系统模块

Node.js 中内置了多个功能模块,这些模块为开发者提供了丰富的功能。以下是几个常用的模块及其使用方法。


一、fs 文件模块

文件模块用于读取和写入文件。

1. 引用文件模块

let fs = require('fs');

fs 是 Node.js 内置的文件模块。

2. 读取文件

读取文件默认使用 UTF-8 编码。

fs.readFile('路径', 'utf8', function(err, res) {  if (err === null) {    console.log(res);  }});

3. 写入文件

默认使用 UTF-8 编码,可以自动创建文件孙存在的路径。

fs.writeFile('路径', '内容', function() {});

二、path 路径模块

路径模块用于拼接路径,支持不同操作系统的路径分隔符。

1. 引用路径模块

let path = require('path');

2. 拼接路径

路径拼接时无需自行添加分隔符。

let path = path.join('路径1', '路径2');

3. 绝对路径和相对路径

// 读取当前文件的绝对路径let currentDir = __dirname;// 构建绝对路径let abstPath = path.join(currentDir, './文件名');

三、http 模块

用于创建HTTP服务器,处理客户端请求。

1. 创建服务器

const http = require('http');const app = http.createServer();app.on('request', function(req, res) {  // 处理请求逻辑});app listening on 3000 port

2. 获取请求方法

if (req.method === 'POST') {  // 处理 POST 请求}

3. 请求对象 (req)

  • req.headers : 请求头信息
  • req.url : 请求地址
  • req.method : 请求方法

4.响应对象 (res)

  • res.end() : 输出回复内容
  • res.writeHead() : 设置 HTTP 响应状态码和内容类型

5. 处理 POST 请求参数

let params = '';req.on('data', function(data) {  params += data;});req.on('end', function() {  // 处理参数逻辑});

四、url 模块

用于解析和处理URL地址。

1. 解析 URL 参数

const url = require('url');let parsedUrl = url.parse(req.url, true);// parsedUrl.search 是查询字符串,parsedUrl.query 是对象形式。

2. 获取请求地址

let pathname = url.parse(req.url).pathname;

五、querystring 模块

用于解析 key-value 查询字符串。

1. 引用查询字符串模块

let querystring = require('querystring');let params = querystring.parse(searchStr);

六、utility 模块

提供 utilities 函数,支持 promise 异步操作。

1. 异步操作处理

const fs = require('fs');const util = require('util');const readFile = util.promisify(fs.readFile);

七、第三方插件——mime 模块

用于根据请求 URL 返回文件 MIME 类型。

1. 安装 mime 模块

npm install mime

2. 获取 MIME 类型

const mime = require('mime');let type = mime.getType(url); // 返回如'text/html', 'text/css'等

八、案例:根据地址返回不同内容

const http = require('http');const url = require('url');const path = require('path');const fs = require('fs');const app = http.createServer();app.on('request', function(req, res) {  let pathname = url.parse(req.url).pathname;  let readFilePath = path.join(__dirname, pathname);  fs.readFile(readFilePath, 'utf8', function(err, content) {    if (err) {      res.writeHead(404, {'Content-Type': 'text/html; charset=utf-8'});      res.end('文件读取失败');      return;    } else {      res.writeHead(200, {'Content-Type': 'text/html; charset=utf-8'});      res.end(content);    }  });});app.listen(3000);console.log('服务器已启动');

以上说明涵盖了 Node.js 的核心模块及其应用示例,适合技术人员参考和使用。

转载地址:http://hneuk.baihongyu.com/

你可能感兴趣的文章
NHibernate示例
查看>>
nid修改oracle11gR2数据库名
查看>>
NIFI1.21.0/NIFI1.22.0/NIFI1.24.0/NIFI1.26.0_2024-06-11最新版本安装_采用HTTP方式_搭建集群_实际操作---大数据之Nifi工作笔记0050
查看>>
NIFI1.21.0_java.net.SocketException:_Too many open files 打开的文件太多_实际操作---大数据之Nifi工作笔记0051
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_插入时如果目标表中已存在该数据则自动改为更新数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0058
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0_Postgresql和Mysql同时指定库_指定多表_全量同步到Mysql数据库以及Hbase数据库中---大数据之Nifi工作笔记0060
查看>>
NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
查看>>
NIFI1.21.0最新版本安装_配置使用HTTP登录_默认是用HTTPS登录的_Https登录需要输入用户名密码_HTTP不需要---大数据之Nifi工作笔记0051
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增加修改实时同步_使用JsonPath及自定义Python脚本_03---大数据之Nifi工作笔记0055
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现update数据实时同步_实际操作05---大数据之Nifi工作笔记0044
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>