Nodejs(文件操作,构建服务器,express,npm)

news2024/11/18 21:29:09

文章目录

  • 文件操作
    • 1.读取文件
      • 1)步骤
      • 2)范例
    • 2.写文件
      • 1)步骤
      • 2)范例
    • 3.删除文件
    • 4.重命名文件夹
    • 5删除文件夹
  • Url
    • 1.url.parse()
    • 2.url.fomat()
  • Query
    • 1.query.parse()
    • 2.query.stringfy()
    • 3.编码和解码
  • 第三方模块
    • 1.nodemailer
    • 2.body-parser
  • 构建服务器
    • 2.响应
      • 范例1
      • 范例2(end)
      • 范例3(将对象等变为字符串)
  • Node中的js
    • 1.核心模块(内置~)
    • 2.模块系统
      • 1)加载与导出
  • ip地址和端口的概念
  • 响应内容类型 Content-Type
  • 发送文件中的数据
  • npm
  • Node 简易爬虫
  • Express
    • 1.Experss基本使用
      • 1)步骤
      • 2)API接口的构成要素
      • 3)API接口的书写
  • express 路由
  • 中间件(middlewear)
    • 1.自定义中间件
      • 1)全局
      • 2)局部中间件
    • 2.内置中间件(静态资源目录)
  • node 中的异步操作
  • 异步回调promise
    • 1.promise
    • 2.promise链式调用

文件操作

1.读取文件

1)步骤

  • 使用require方法加载fs核心模块
  • 读取文件
//使用require方法加载fs核心模块
var fs=require('fs')
//读取文件
// 参数1:读取的文件的路径
// 参数2:回调函数
//     成功:data:数据
//           error: null
//     失败:data:undefined
//           error:错误对象

fs.readFile('',function(error,data){});

2)范例

在这里插入图片描述
helloworld.js

var fs = require("fs");

fs.readFile("hello.txt", function (error, data) {
  console.log(data);
});

hello.txt

hello Node

在这里插入图片描述

在这里插入图片描述

2.写文件

1)步骤

//使用require方法加载fs核心模块
var fs=require('fs')
//写文件
// 参数1:文件的路径
// 参数3:文件内容
// 参数2:回调函数
//     成功:文件写入成功
//           error: null
//     失败:文件写入失败
//           error:错误对象

fs.readFile('',function(error){});

2)范例

写文件.js

var fs = require("fs");
fs.writeFile("写文件.txt", "腹有诗书气自华", function (error) {
  console.log("文件写入成功");
});

在这里插入图片描述

在这里插入图片描述

注意:如果文件不存在,会创建文件,并写入指定内容,如果文件存在,则内容会被重新覆盖

要想不被覆盖,可以使用appendFile,追加在后面

3.删除文件

var fs=require('fs');
fs.unlink('./创建文件.txt',function(error){
})
3.创建文件夹
var fs=require('fs');
fs.mkdir('./创建文件',function(error){
})

4.重命名文件夹

var fs=require('fs');
fs.mkdir('./创建文件','./重命名文件',function(error){
})

5删除文件夹

注意只能删除空文件

var fs=require('fs');
fs.rmdir('./创建文件',function(error){
})

Url

1.url.parse()

将url字符串转换成对象

var url=require('url');
let urlString='http:49.95.207.1:3000/fcj/recommend/hot/hehe?us=123#nihao'
let urlObj=url.parse(urlString);
console.log(urlObj)

在这里插入图片描述

2.url.fomat()

将url对象转换成字符串

let obj = {
  protocol: "http:",
  slashes: null,
  auth: null,
  host: null,
  port: null,
  hostname: null,
  hash: "#nihao",
  search: "?us=123",
  query: "us=123",
  pathname: "49.95.207.1:3000/fcj/recommend/hot/hehe",
  path: "49.95.207.1:3000/fcj/recommend/hot/hehe?us=123",
  href: "http:49.95.207.1:3000/fcj/recommend/hot/hehe?us=123#nihao",
};
let string = url.format(obj);
console.log(string);

在这里插入图片描述

Query

1.query.parse()

将字符串变为对象
在这里插入图片描述

2.query.stringfy()

将对象变为字符串
在这里插入图片描述

3.编码和解码

在这里插入图片描述

第三方模块

1.nodemailer

const nodemailer = require("nodemailer");
// 创建发送邮件的请求对象
const transporter = nodemailer.createTransport({
  host: "smtp.qq.com", //发送方邮箱 通过lib/wellknown/services.json
  port: 465,
  secure: true, // Use `true` for port 465, `false` for all other ports
  auth: {
    user: "2843306836@qq.com", //发送方的邮箱地址
    pass: "vsclqhgqfpuxdecd", //mtp验证码
  },
});
// 邮件信息
let mailobj = {
  from: '"Maddison Foo Koch 👻" <2843306836@qq.com>', // sender address
  to: "2843306836@qq.com", // list of receivers  初设bar@example.com, baz@example.com
  subject: "Hello ✔", // Subject line
  // 文本信息和html信息只能有一个
  text: "您的验证码是8520,有效期为五分钟", // plain text body

  // html: "<b>Hello world?</b>", // html body
};
// 发送邮件
transporter.sendMail(mailobj, function (error, data) {});

2.body-parser

var express = require('express')
var bodyParser = require('body-parser')

var app = express()
// app.use表示使用中间件

// 解析表单数据
app.use(bodyParser.urlencoded({ extended: false }))

// 解析json数据
app.use(bodyParser.json())

app.use(function (req, res) {
  res.setHeader('Content-Type', 'text/plain')
  res.write('you posted:\n')
  res.end(JSON.stringify(req.body, null, 2))
})

构建服务器

在Node中提供了一个核心模块,http
这个模块用来创建编写服务器
1.简单的http服务
1)步骤
● 加载http核心模块
● 使用http.createServer()方法加载一个服务器
● 提供服务:对数据的服务
发请求
接收请求
处理请求
给反馈(发送响应)
注册request请求事件
当客户端请求过来,就会自动触发服务器的request请求事件,执行第二个参数,回调处理函数
● 绑定端口号,启动服务器

// 加载http核心模块
var http=require('http');
// 使用http.createServer()方法加载一个服务器
// 返回一个Server实例
var server=http.createServer();
// 提供服务(当服务器接受请求之后要干的事)
sever.on('request'function(){...})
// 绑定端口号,启动服务器
server.listen(3000,function(){});

2)范例
在这里插入图片描述
注意:当运行时会打印出在这里插入图片描述
此时控制台无法输入任何东西,因为在等待客户端请求
只有当在浏览器输入网址时,控制台会打印出
在这里插入图片描述
ctrl+c可以直接关闭服务器

2.响应

request请求事件处理函数需要接受两个参数:
Request请求对象
请求对象可以用来获取客户端的一些请求信息,例如请求路径
Response响应对象
响应对象可以用来给客户端发送响应消息

response对象有一个方法:write可以用来给客户端发送响应数据

write可以使用多次,但是最后一定要使用end来结束响应(告诉客户端话说完了,可以呈递给用户),否则客户端会一直等待
响应内容只能是二进制数据或者字符串

范例1

在这里插入图片描述
在这里插入图片描述

范例2(end)

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

范例3(将对象等变为字符串)

在这里插入图片描述
在这里插入图片描述

Node中的js

Node只能执行一个文件

1.核心模块(内置~)

Node 为js提供了很多服务器级别的API,这些API绝大多数都被包装到了一个具名的核心模块中
例如文件操作的fs核心模块,http服务构建的http模块,path路径操作模块,os操作信息模块
在这里插入图片描述

2.模块系统

在这里插入图片描述
equire是一个方法,它的作用之一就是用来加载模块的
在Node中,模块有三种:
具名的核心模块:fs,http…
用户自己编写的文件模块

注意:在node中没有全局作用域只有模块作用域(即超出文件的函数或者变量声明不起作用)
外部访问不到内部,内部也访问不到外部
相对路径必须加./
可以省略后缀名

在这里插入图片描述
在这里插入图片描述

1)加载与导出

require方法有两个作用:
1.加载文件模块并执行里面的代码
2.拿到被加载文件模块导出的接口对象

在每个文件中都提供了一个对象:exports
exports默认是一个空对象
在这里插入图片描述
要做的就是把所有需要被外部访问的成员挂载到exports对象中
若要直接使用foo, 打印 ret.foo 输出hello
在这里插入图片描述

ip地址和端口的概念

所有联网的程序都需要进行网络通信
计算机中只有一个物理网卡,而且同一个局域网中,网卡的地址必须是唯一的
网卡是通过唯一的ip地址来进行定位的
ip地址用来定位计算机,端口号用来定位具体的应用程序
所有需要联网通信的软件都需要端口号
端口号的范围0~65536之间
可以同时开启多个服务,但一定要确保不同服务占用的端口号不一致

响应内容类型 Content-Type

浏览器在不知道服务器响应内容的编码的情况下会按照当前操作系统的默认编码(utf8)去解析
会导致中文乱码,中文操作系统默认是gbk

在http协议中,Content-Type就是用来告知对方发送的数据内容是什么类型
在线查询工具
https://tool.oschina.net/ 中的Http Mime-type

var http=require('http');
var server=http.createServer();
server.listen(3000,function(){
  console.log("Server is running")
})
server.on('',function(req,res){
  //防止乱码
  res.setHeader('Content-Type','text/plain;charset=utf-8')
  res.end("hello 世界")
})

发送文件中的数据

1.结合fs发送文件中的数据
2.Content-Type
不同资源对应的Content-Type不一样
图片不需要指定编码,一般只为字符数据指定编码

npm

1.npm命令

npm init -y // 可以跳过向导 ,快速生成
npm install //一次性把dependencies全部安装
npm install 包名  //只下载   简写 npm i 包名
npm install --save 包名  //下载并保存依赖项(package.json文件中的dependencies)  简写npm -S 包名 
 
npm uninstall 包名  //只删除,依赖项会保存  简写 npm un 包名
npm uninstall --save //删除的同时依赖信息也去除  简写 npm un -S包名

Node 简易爬虫

获取目标网站
分析网站内容
获取有效信息,下载或者其他操作

Express

通过express框架书写API
非关系数据库mongodb
1.什么是API
在这里插入图片描述
2.登录接口逻辑分析
● 接收用户传递数据
● 处理数据
● 返回数据

1.Experss基本使用

1)步骤

安装express

var express = require("express");
var app = express();
// 最简单的APi接口
app.get("/user/login", function (req, res) {
  console.log("你好");
  res.send("注册成功");
});
app.listen(3000, function () {
  //监听300端口 开启服务器
  console.log("server start");
});

2)API接口的构成要素

ip
port
pathname
method :get post
接收用户数据 数据格式后端决定

get请求 用req.query接受参数
在这里插入图片描述

3)API接口的书写

接收数据

● get req.query
● post req.body
需要第三方插件body-parser 插件进行解析
注意数据格式 json x-www-form-urlencoded formdata

express 路由

由于接口会有公共的网址 例如user/del user/add
为了使代码简化,可以使用路由
在这里插入图片描述

userRouter.js

var express = require("express");
var router = express.Router();

router.get("/add", function (req, res) {
  res.send("user add");
});

router.get("/del", function (req, res) {
  res.send("user del");
});

module.exports = router;

server.js

var express = require("express");
var app = express();

let userRouter = require("./router/userRouter");
app.use("/user", userRouter);

app.listen(3000, function () {
  console.log("server start");
});

在这里插入图片描述

中间件(middlewear)

内置中间件
自定义中间件(全局 局部)
第三方中间件

1.自定义中间件

1)全局

全局自定义

var express = require("express");
var app = express();


// next 是否继续往下执行
app.use("/", function (req, res, next) {
  console.log("中间件");
  // next()
});

// 如果是根路径/  即上面代码等价于
// app.use(function (req, res, next) {
//   console.log("中间件");
//   // next()
// });

app.listen(3000, function () {
  console.log("server.start");
});
app.get("/test1", function (req, res) {
  console.log("test1");
  let { token } = req.query;
  if (token) {
    res.send("ok");
  } else {
    res.send("no");
  }
});
app.get("/test2", function (res, req) {
  console.log("test2");
  if (token) {
    res.send("ok");
  } else {
    res.send("no");
  }
});

在这里插入图片描述
在这里插入图片描述

当运行并发送请求时,被app.use拦截
因为中间件用的 /
/text1 /text2 中间件都具有这个符号
当发送请求时,会优先处理中间件的处理函数
如果中间件处理函数中有next() 会继续往下执行

2)局部中间件

var express = require("express");
var app = express();

app.listen(3000, function () {
  console.log("server.start");
});

app.get(
  "/test1",
  function (req, res, next) {
    console.log("fun1");
    next();
  },
  function (req, res) {
    console.log("fun2");
    res.send("test1");
  }
);

2.内置中间件(静态资源目录)

指定一个目录(如hehe),可以被访问
在这里插入图片描述
__dirname可以获得代码所在文件的绝对路径E:\Nodejs\products,然后将目标目录相对于staitc.js的相对路径拼接拼接

static.js

// 让hehe变为可访问
var express = require("express");
var app = express();
var path = require("path");
// console.log(__dirname);
// console.log(path.join(__dirname, "./hehe"));

app.listen(3000, function () {
  console.log("server start");
});

app.use(express.static(path.join(__dirname, "./hehe")));

在这里插入图片描述
如果app.use(‘/public’,express.static(path.join(__dirname, “./hehe”)));
在这里插入图片描述

node 中的异步操作

● fs模块对文件的几乎所有操作都有同步和异步两种形式
● 例如:readFile()和readFileSync()
● 区别:
同步调用会阻塞代码的执行,异步则不会
异步调用会将读取任务下达到任务队列,直到任务执行完成才会回调
异常处理方面,同步必须使用try,catch方式,异步可以通过回调函数的第一个参数

异步回调promise

如果异步操作需要保持一定的执行顺序 则需要回调函数的嵌套来实现 会导致回调地域

解决方法:promise asyc /await(es7)

1.promise

promise是抽象的异步处理对象以及对其进行各种操作的组件,promise并不是从javaScript中发祥的概念
promise最初被提出是在E语言中,它是基于并列/并行处理设计的一种编程语言
现在js也拥有该特性,就是js promise

var fs = require("fs");

// 将异步操作封装到promise函数里
function delfile() {
  return new Promise(function (resolve, reject) {
    // 异步操作

    fs.unlink("./hehe.js", function (err) {
      if (err) {
        reject("失败了");//会向.then 函数传递信息 msg=失败了
      } else {
        resolve("成功");//err=成功 
      }
    });
  });
}
// promise对象可以跟两个函数.then .catch
// 如果执行reject 走catch
// 如果执行resolve 走.then
delfile()
  .then(function (msg) {
    console.log("then" + msg);
  })
  .catch(function (err) {
    console.log("catch" + err);
  });

2.promise链式调用

在一组链式调用中只需要一个catch

var fs = require("fs");
const { resolve } = require("path");
// 1.封装
function isExist() {
  return new Promise(function (resolve, reject) {
    fs.stat("./hehe.js", function (err, stats) {
      if (err) {
        reject("文件不存在");
      } else {
        resolve("文件存在");
      }
    });
  });
}

function delfile() {
  return new Promise(function (resolve, reject) {
    fs.unlink("./hehe.js", function (err) {
      if (err) {
        reject("删除失败");
      } else {
        resolve("删除成功");
      }
    });
  });
}

isExist()
  .then(function () {
    console.log("isExist 的成功处理");
    return delfile();
  })
  .then(function () {
    console.log("删除文件的成功处理");
  })
  .catch(function (err) {
    console.log("catch");
    console.log(err);
  });

在这里插入图片描述
理解:isExist函数返回的是一个promise对象,使用.then 方法后执行到return delFile(),会返回一个新的promise对象(用来删除文件),新的promise对象的.then方法会继续执行
无论哪个函数中间执行错误,都会调用catch函数()
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1699736.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

学 C/C++ 具体能干什么?

学习 C 和 C 后&#xff0c;你可以从事许多不同的工作和项目&#xff0c;这两种语言以其高性能和低级控制而闻名&#xff0c;特别适合以下几个领域&#xff1a; 1. 系统编程 C 和 C 是系统编程的首选语言&#xff0c;适用于操作系统、驱动程序和嵌入式系统开发。 操作系统开发…

VLC播放器(全称VideoLAN Client)

一、简介 VLC播放器&#xff08;全称VideoLAN Client&#xff09;是一款开源的多媒体播放器&#xff0c;由VideoLAN项目团队开发。它支持多种音视频格式&#xff0c;并能够在多种操作系统上运行&#xff0c;如Windows、Mac OS X、Linux、Android和iOS等。VLC播放器具备播放文件…

SSH 远程登录系统和远程拷贝

文章目录 目录 文章目录 前言 一.SSH的基本用法 SSH基本用法&#xff1a; SSH无密码登录 二.SSH安全设置 三.SSH限制用户 前言 很多时候服务器并没有服务器&#xff0c;我们也不能每次都通过控制台去管理服务器&#xff0c;这时候就需要远程登录&#xff0c;相比于Telnet&a…

vue项目打包教程

如果是用 vue-cli 创建的项目&#xff0c;则项目目录中没有 config 文件夹&#xff0c;所以我们需要自建一个配置文件&#xff1b;在vue项目目录下创建文件 vue.config.js&#xff0c;需注意文件名称必须是 vue.config.js&#xff0c;然后在文件中插入以下代码&#xff1a; 文件…

PyTorch深度学习快速入门——P1-P13

环境配置 Anaconda&#xff0c;创建conda create -n pytorch python3.12&#xff0c;使用conda activate pytorch切换到环境。安装pytorch&#xff0c;conda install pytorch torchvision torchaudio pytorch-cuda11.8 -c pytorch -c nvidia&#xff0c;使用import torch&…

用常识滚雪球:拼多多的内生价值,九年的变与不变

2024年5月22日&#xff0c;拼多多公布了今年一季度财报&#xff0c;该季度拼多多集团营收868.1亿元&#xff0c;同比增长131%&#xff0c;利润306.0亿&#xff0c;同比增长了202%&#xff0c;数据亮眼。 市场对拼多多经历了“看不见”、“看不懂”、“跟不上”三个阶段。拼多多…

【图论】最短路(一)

发现之前做的题很乱&#xff0c;用小笔记把看过的博客和题目分类记录一下&#xff0c; 代码参考了很多佬&#xff0c;是标注出来的链接&#xff0c;若不同意我就删掉&#xff08;鞠躬&#xff09; 找了几张好点的&#xff0c;图来源图中的id和acwing 1.dijkstra 依次找到距…

【Week-R1】RNN实现心脏病预测,基于tensorflow框架

文章目录 一、什么是RNN&#xff1f;二、准备环境和数据2.1 导入数据 三、构建模型四、训练和预测五、其他&#xff08;1&#xff09;sklearn模块导入报错&#xff1a;ModuleNotFoundError: No module named sklearn&#xff08;2&#xff09;优化器改为SGD&#xff0c;accurac…

FTP协议——BFTPD基本操作(Ubuntu+Win)

1、描述 本机&#xff08;Win10&#xff09;与虚拟机&#xff08;Ubuntu22.04.4&#xff09;上的BFTPD服务器建立FTP连接&#xff0c;执行一些基本操作。BFTPD安装教程&#xff1a;FTP协议——BFTPD安装&#xff08;Linux&#xff09;-CSDN博客 2、 步骤 启动BFTPD。启动文件…

BGP选路规则

配置地址&#xff0c;AS123使用ospf保证通讯&#xff0c;修改接口类型保证ospf学习环回20.0,30.0,100.0 地址时&#xff0c;是以24位掩码学习&#xff0c;R1&#xff0c;R2&#xff0c;R3都处于BGP边界&#xff0c;各自都需要宣告三者的私网环回 1&#xff0c; [R4]ip ip-prefi…

Radware Alteon负载均衡-配置证书组

证书组&#xff1a;可以使用证书组将多个服务器证书与虚拟服务相关联。这提供了对服务器名称指示(Server Namelndication&#xff0c;SNI)的支持&#xff0c;允许在相同的IP和端口后面托管多个主机名。使用SNI&#xff0c;浏览器发送请求的主机名&#xff0c;使服务器能够在进行…

【机器学习300问】96、怎么理解卷积神经网络CNN中的卷积操作?

卷积操作是卷积神经网络&#xff08;CNN&#xff09;中的一种核心组件。要讲清楚卷积操作&#xff0c;我们只需要回答以下四个问题&#xff1a;什么是卷积核&#xff1f;卷积运算的规则是什么&#xff1f;padding是什么&#xff1f;stride是什么&#xff1f; 下面让我以图像处理…

嵌入式进阶——蜂鸣器

&#x1f3ac; 秋野酱&#xff1a;《个人主页》 &#x1f525; 个人专栏:《Java专栏》《Python专栏》 ⛺️心若有所向往,何惧道阻且长 文章目录 蜂鸣器原理图测试发声乐理知识乐理应用PWM测试发声PWM驱动封装 蜂鸣器 蜂鸣器是一种能够产生固定频率的声音的电子元件。它通常由…

没有电商经验的人去操作抖音小店,难度大不大?好操作吗?

大家好&#xff0c;我是电商小V 很多新手小伙伴想去操作抖音小店项目&#xff0c;咨询的最多的问题就是我没有电商运营的经验可以去操作吗&#xff1f; 当然是可以操作的&#xff0c;抖音小店项目对于新手来说是一个非常友好的项目&#xff0c;很多小伙伴都是感觉没有电商经验去…

产品经理-流程图结构图(四)

1. 流程图 1.1 概念 为了达到特定的目标而进行的一系列有逻辑性的操作步骤&#xff0c;由两个及以上的步骤&#xff0c;完成一个完整的行为的过程&#xff0c;可称之为流程 1.2 产品经理为什么需要绘制流程图&#xff1f; 保证产品的使用逻辑合理顺畅向项目组其他成员清晰的…

2024最新前端面试八股文【基础篇293题】

⼀、HTML、HTTP、web综合问题 1 前端需要注意哪些SEO 2 <img> 的 title 和 alt 有什么区别 3 HTTP的⼏种请求⽅法⽤途 4 从浏览器地址栏输⼊url到显示⻚⾯的步骤 5 如何进⾏⽹站性能优化 6 HTTP状态码及其含义 7 语义化的理解 8 介绍⼀下你对浏览器内核的理解 9 …

QT常量中有换行符

头文件添加&#xff1a; #pragma execution_character_set("utf-8")

深入理解计算机系统 家庭作业4.52

练习题4.3 p.254 \sim\seq\seq-full.hcl文件内已经说的很清楚了哪些不能更改,哪些是题目要求更改的控制逻辑块. 依据家庭作业4.51的答案,在seq-full.hcl文件内更改对应的HCL描述即可 以下答案注释了#changed的就是更改部分 #/* $begin seq-all-hcl */ ######################…

CCF CAT- 全国算法精英大赛(2024第二场)往届真题练习 3 | 珂学家

前言 这是2024年第一场CCF初赛的题&#xff0c; 其实整场比赛&#xff0c;感觉不是特别难&#xff0c;就是码量大&#xff0c;偏模拟和数学。 对于A题&#xff0c;摩斯密码&#xff0c;很容易抄错&#xff0c;我一直在想有什么好办法可以规避它&#xff0c;是真的苦涩。 真题…

Linux系统启动原理

Linux系统启动原理及故障排除 Centos6系统启动过程 修改系统启动级别 vim /etc/inittabCentos7启动流程 加载BIOS信息&#xff0c;进行硬件检测 根据BIOS设定读取设备中的MBR&#xff0c;加载Boot loader 加载内核&#xff0c;内核初始化以后以模块的形式动态加载硬件 并且加…