IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Express基础 -> 正文阅读

[JavaScript知识库]Express基础

Express

什么是express?

Express是基于Node.js平台,快速,开放,极简的Web框架。
其作用与Node.js内置的http模块类似,都是用来创建Web服务器的。
Express本质上就是一个npm上的第三方包,提供了快速搭建Web服务器的简便方法。
Express中文官网:https://www.expressjs.com.cn/

Express的优势

在没有express的情况下,仍然可以使用Node.js内置的http模块创建Web服务器,而express是基于内置http模块进一步封装出来的,能够极大的提高开发效率。express与http内置模块的关系就好比Web API与Jquery之间的关系,后者是基于前者进一步封装出来的。

Express的基本使用

安装

npm install express@4.17.1

创建最基本的Web服务器

# 导入express模块
const express = require("express");
# 调用express()函数返回一个实例,创建Web服务器
const server = express();
# 调用server.listen(端口号,启动成功的回调函数),启动服务器
server.listen(80,()=>{
	console.log("服务器创建成功!");
})

监听GET请求

使用实例的get方法,可以监听客户端的get请求
get方法的参数:url字符串,请求对应的处理函数

参数描述
URL字符串客户端请求的URL
req请求对象,包含了与请求相关的属性和方法
res响应对象,包含了与响应相关的属性和方法
server.get("请求URL",function(req,res){
	
});

监听POST请求

与监听GET请求基本一致

server.post("请求URL",function(req,res){
	
});

将内容响应给客户端

server.get("请求URL",function(req,res){
	// 向客户端发送json对象
	res.send({name:"Chen",age:18});
	// 向客户端发送文本
	res.send("get请求成功!");
});

获取URL中携带的查询参数

通过req.query对象,可以获取URL中携带的查询参数。req.query默认是个空对象,当客户端发送请求时使用?name=cpf&age=18这种 查询字符串时,可以通过req.query访问到相应的属性。比如req.query.name或者req.query.age

server.get("请求URL",(req,res)=>{
	console.log(req.query);   //默认是空对象{}
});

获取URL中的动态参数

通过req.params对象可以获取请求URL中通过:匹配的动态参数
首先编写get请求

server.get("/user/:id",(req,res)=>{
	// 上面请求URL中的:id是一个动态参数
	res.send(req.params);
});

然后在postman中测试请求地址
在postman中测试请求URL
查看响应结果
查看响应结果

向外托管静态资源

使用express.static()方法可以对外共享静态资源,方法中需要指定对外共享的文件夹,值得一提的是我电脑里直接用相对地址(./newStruct)没有用,无奈试了一下绝对地址,发现又可以了

const path = require("path");
const express = require("express");
const server = express();
// express.static方法我这里使用了绝对地址,newStruct是需要对外共享的文件夹
server.use(express.static(path.join(__dirname,"newStruct")));
server.listen(80,()=>{
	console.log("托管静态资源的服务器已启动 http://127.0.0.1");
});

如果需要对外托管多个文件夹,则需要多次调用express.static()即可,当对外托管多个静态资源目录时,如果访问一个在多个文件夹都有的文件名时,会按照托管顺序进行检索

server.use(express.static(path.join(__dirname,"文件夹1")));
server.use(express.static(path.join(__dirname,"文件夹2")));

挂载路径前缀

如果想要在托管的静态资源之前添加路径前缀,即在访问时需要在前面添加一个前缀才可以访问成功。可以使用以下方式:

server.use("/yes",express.static(path.join(__dirname,"newStruct")));

nodemon工具

在编写调试Node.js的项目时,每次修改完代码都需要手动关闭服务器,再重新打开,非常繁琐。这时可以使用nodemon这个工具,它能够监听文件的变动,在代码被修改时,自动帮助我们重启服务器,极大方便了测试与开发。

npm i nodemon -g

在执行js文件时,将node替换为nodemon即可

nodemon app.js

Express路由

什么是Express路由

比如我们拨打三大运营商的人工客服电话,会提示我们通过按键进行服务的选取,每个按键会对应一种服务,这种按键与服务之间的映射关系就是路由。
Express中的路由是指客户端的请求服务器中处理函数之间的关系。

Express的路由由三部分组成:请求的类型(METHOD)、请求URL(PATH)、对应处理函数(HANDLER)

server.METHOD(PATH,HANDLER);

例子:

// 匹配GET请求,且请求的URL为 /
server.get("/",(req,res)=>{
	res.send("give you a gift");
});
// 匹配POST请求,且请求的URL为 /
server.post("/",(req,res)=>{
	res.send("Got a POST request");
});

Express路由的匹配过程

每当服务器受到一个请求,需要先经过路由的匹配,服务器会依次按照路由的挂载顺序进行匹配,如果请求类型请求URL都匹配成功,则Express会将这次请求转交给对应的处理函数进行处理。

模块化路由

为了方便对路由进行模块化管理,Express不建议将路由直接挂载到server实例上,而是推荐将路由抽离为一个单独模块。
创建模块化路由可遵循以下几个步骤:

  1. 创建路由模块.js文件
  2. 调用express.Router()方法创建路由实例
  3. 向路由实例上挂载具体的路由
  4. 使用module.exports向外暴露路由对象
  5. 使用server.use()方法注册路由模块

router.js文件

const express = require("express");
// 创建一个路由对象
const router = express.Router();
// 挂载具体路由
router.get("\",(req,res)=>{
	res.send("收到了一个get请求");
});
router。post("\",(req,res)=>{
	res.send("收到了一个post请求");
});
// 将router向外暴露
module.exports = router;

Server.js文件

const express = require("express");
const server = express();
// 给服务器server注册路由
server.use(router);
server.listen(80,()=>{
	console.log("服务器已启动!");
});

最后通过nodemon执行Server.js文件

nodemon Server.js

Express中间件

什么是中间件

中间件(Middleware),特指业务流程的中间处理环节。

Express中间件的调用流程

当一个请求到达服务器时,可以连续调用多个中间件,从而对这次请求进行预处理。多个中间件共享同一份req和res。
中间件的调用流程

Express中间件的格式

Express的中间件,本质上是一个function处理函数。与路由处理函数的区别在于,中间件函数的形参中必须包含next参数,而路由处理函数只有reqres两个形参。
Express中间件

中间件形参next函数的作用

next函数是实现多个中间件连续调用的关键,它表示把流转关系转交给下一个中间件或路由。

定义中间件函数

定义一个简单的中间件

const mw = function(req,res,next){
	console.log("经过了中间件处理");
	// 把流转关系转到下一个中间件或路由
	next();
}

定义一个全局生效的中间件,所谓全局生效的中间件,就是客户端发起的任何请求,到达服务器之后都会经过这个中间件进行处理。
我们通过server.use(中间件函数);即可定义一个全局中间件

server.use(mw);

定义局部中间件

server.get("/",[mw1,mw2],(req,res)=>{
	// 指定请求URL指定方法的中间件,多个中间件可以用数组包起来
});

错误级别的中间件

错误级别的中间件的作用:专门用来捕获整个项目中发生的异常错误,从而防止项目异常崩溃的问题。
在错误级别的中间件中,必须要有4个参数,从左至又分别是err,req,res,next。需要注意的是,错误级别的中间件需要注册到所有路由之后

server.use(function(err,req,res,next){
	console.log("Error:"+err.message);
	res.send("发生了错误:"+err.message);
});

Express内置的中间件

自Express4.16.0之后,Express内置了3个中间件,极大的提高了开发效率。

  1. express.static() 用于快速托管静态资源的内置中间件且无兼容性问题。例如html文件,图片,css样式等
  2. express.json() 用于解析JSON格式的请求数据(4.16.0+)
  3. express.urlencoded() 用于解析URL-encoded格式的请求数据(4.16.0+)

使用中间件的注意事项

  1. 除错误级别的中间件,其他中间件需要要在注册路由之前注册
  2. 当执行完中间件的代码时要调用next()函数,并且调用next()函数后不要再写代码
  3. 连续调用多个中间件时,多个中间件之间共享req和res对象

使用Express编写接口

先创建两个文件,分别是router.js和运行服务器的文件server.js
router.js

// 导入express
const express = require("express");
// 导入moment
const moment = require("moment");
// 调用express.Router()方法创建一个路由实例
const router = express.Router();

function ResData() {
	this.status = 0;
	this.msg = "请求成功!";
	this.data = {};
	this.time = moment().format("YYYY年MM月DD日 hh:mm:ss");
}

// 编写API接口

//#region 编写一个get接口
router.get("/get", (req, res) => {
	// 通过req.query获取查询字符串
	const query = req.query;
	// 将query作为返回值返回给客户端
	let resData = new ResData();
	resData.msg = "get请求成功!";
	resData.data = query;
	res.send(resData);
});
//#endregion

//#region 编写一个post接口
router.post("/post", (req, res) => {
	// 通过body来获取请求体中包含 url-encoded 格式的数据,但前提要先通过一个中间件来解析表单的请求体,并封装到req.body中
	const body = req.body;
	// 通过res.send()将请求的数据作为响应数据返回
	let resData = new ResData();
	resData.msg = "post请求成功!";
	resData.data = body;
	res.send(resData);
});
//#endregion
// 将路由实例向外共享
module.exports = router;

server.js

// 导入express
const express = require("express");
// 创建一个express实例
const server = express();
// 导入自己编写的路由模块进行使用
const router = require("./router");
// 配置解析表单请求体的中间件
server.use(express.urlencoded({ extended: false }));

// 将router实例注册到服务器上,并且添加/api前缀
server.use("/api", router);

// 注册一个错误级别的中间件用于处理错误
server.use((err, req, res, next) => {
	console.log("发生了一个错误:" + err.message);
	res.send("发生了一个错误:" + err.message);
});
// 启动服务器
server.listen(80, () => {
	console.log("express server running at http://127.0.0.1");
});

接口的跨域问题

当我们在本地创建一个html页面,并且借助Jquery中的ajax向接口请求数据时,就会受到浏览器同源安全策略的影响,产生跨域问题。
由于使用的协议不一致,一个是http协议,一个是file协议,导致出现跨域问题。

跨域问题的解决

第一种方法是使用JSONP方案解决,缺陷是只能支持get请求
第二种方法是使用CORS方案,是目前的主流方案,推荐使用

使用CORS中间件解决跨域问题

cors(Cross-Origin Resource Sharing,跨域资源共享),由一系列HTTP响应头组成,这些HTTP响应头决定了浏览器是否要阻止前端js代码跨域获取资源。它是Express的一个第三方中间件,通过安装和配置cors中间件,可以很方便的解决跨域问题。
使用步骤:
安装cors中间件

npm install cors

在server.js中引入cors中间件

const cors = require("cors");

在路由之前注册cors

server.use(cors());

在这之前还需要配置一个JSONP的接口,防止通过JSONP接口的请求被当成CORS的请求,进而二者间产生冲突。
在注册CORS之前需要配置JSONP的一个接口。

server.get("/api/jsonp",(req,res)=>{
	// jsonp只支持get请求,所以只要设置get请求的即可
});

// 然后再注册cors中间件
server.use(cors());

接下来就可以通过js正常访问配置了cors的接口了。

在服务器端实现JSONP接口

思路:

  1. 获取客户端发送回来的回调函数的名字
  2. 得到要通过JSONP响应给客户端的数据
  3. 根据前两步的数据,拼接出一个函数的调用的字符串
  4. 把拼接的字符串响应给客户端的<script>标签
// 注意要在注册cors中间件之前设置
server.get("/api/json",(req,res)=>{
	// 先获取客户端请求的函数名
	const funcName = req.query.callback;
	// 定义一个需要响应给客户端的数据
	const data = {name:"李四",age:18};
	// 根据前面得到的函数名和数据拼接一个函数执行的字符串
	const scriptStr = `${funcName}(${data})`;
	// 将拼接的字符串响应给客户端
	res.send(JSON.stringfy(scriptStr));
});

cors在浏览器中有兼容性。只有支持XMLHttpRequest Level2的浏览器,才能够正常访问开启了cors的服务端接口(IE10+,Chrome4+,Firefox3.5+等)

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-07-27 16:07:20  更:2021-07-27 16:08:25 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/4 20:04:02-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码