Express

目录

Express

九、初识Express

9.1 Express简介

1. 什么是 Express

2. 进一步理解Express

3. Express能做什么

9.2 Express的基本使用

1. 安装

2. 创建基本的Web服务器

3. 监听GET请求

4. 监听POST请求

5. 把内容响应给客户端

6. 获取URL中携带的查询参数

7. 获取URL中的动态参数

9.3 托管静态资源

1. express.static()

2. 托管多个静态资源目录

3. 挂载路径前缀

9.4 nodemon

1. 为什么要使用nodemon

2. 安装nodemon

3. 使用nodemon

十、Express路由

10.1 路由的概念

1. 什么是路由

2. 现实生活中的路由

3. Express中的路由

4. Express中的路由的例子

5. 路由的匹配过程

10.2 路由的使用

1. 最简单的用法

2. 模块化路由

3. 创建路由模块

4. 注册路由模块

5. 为路由模块添加前缀

十一、Express中间件

11.1 中间件的概念

1. 什么是中间件

2. 现实生活的例子

3. Express中间件的调用流程

4. Express中间件的格式

5. next函数的作用

11.2 Express中间件的初体验

1. 定义中间件函数

2. 全局生效的中间件

3. 定义全局中间件的简化形式

4. 中间件的作用

5. 定义多个全局中间件

6. 局部生效的中间件

7. 定义多个局部中间件

8. 了解中间件的5个使用注意事项

11.3 中间件的分类

1. 应用级别的中间件

2. 路由级别的中间件

3. 错误级别的中间件

4. Express内置的中间件

5. 第三方的中间件

11.4 自定义中间件

1. 需求描述与实现步骤

2. 定义中间件

3. 监听req的data事件

4. 监听req的end事件

5. 使用querystring模块解析请求体数据

6. 将解析出来的数据对象挂载为req.body

7. 将自定义中间件封装为模块

十二、使用Express写接口

12.1 创建基本的服务器

12.2 创建API路由模块

12.3 编写GET接口

12.4 编写POST接口

12.5 CORS跨域资源共享

1. 接口的跨域问题

2. 使用cors中间件解决跨域问题

3. 什么是CORS

4. CORS的注意事项

5. CORS响应头部- Access-Control-Allow-Origin

6. CORS响应头部 - Access-Control-Allow-Headers

7. CORS响应头部- Access-Control-Allow-Methods

8. CORS请求的分类

9. 简单请求

10. 预检请求

11. 简单请求和预检请求的区别

12.6 JSONP接口

1. 回顾JSONP的概念与特点

2. 创建JSONP接口的注意事项

3. 实现JSONP接口的步骤

4. 实现JSONP接口的具体代码

5. 在网页中使用jQuery发起JSONP请求

九、初识Express

9.1 Express简介

1. 什么是 Express

官方给出的概念:Express 是基于Node.js平台快速、开放、极简Web开发框架

通俗的理解:Express 的作用和Node.js内置的http模块类似,是专门用来创建Web服务器的

Express的本质:就是一个npm上的第三方包,提供了快速创建Web服务器的便捷方法。

Express的中文官网:http://www.expressjs.com.cn/


 

2. 进一步理解Express

思考:不使用Express能否创建Web服务器?

答案:能,使用Node.js提供的原生http模块即可。

思考:既生瑜何生亮(有了http内置模块,为什么还有用Express) ?

答案:http内置模块用起来很复杂,开发效率低;Express 是基于内置的http模块进一步封装出来的, 能够极大的提高开发效率。

思考:http内置模块与Express是什么关系?

答案:类似于浏览器中Web API和jQuery的关系。后者是基于前者进一步封装出来的。
 

3. Express能做什么

对于前端程序员来说,最常见的两种服务器,分别是:

  • Web 网站服务器:专门对外提供Web网页资源的服务器。
  • API 接口服务器:专[ ]对外提供API接口的服务器。

使用Express,我们可以方便、快速的创建Web网站的服务器或API接口的服务器。
 

9.2 Express的基本使用

1. 安装

在项目所处的目录中,运行如下的终端命令,即可将 express 安装到项目中使用:


 


2. 创建基本的Web服务器


3. 监听GET请求

通过app.get()方法,可以监听客户端的GET请求,具体的语法格式如下:


 

4. 监听POST请求

通过app.post()方法,可以监听客户端的POST请求,具体的语法格式如下:


5. 把内容响应给客户端

通过res.send()方法,可以把处理好的内容,发送给客户端:


 


6. 获取URL中携带的查询参数

通过req.query对象,可以访问到客户端通过查询字符串的形式,发送到服务器的参数:



7. 获取URL中的动态参数

通过 req.params 对象,可以访问到URL中,通过 : 匹配到的动态参数


 



9.3 托管静态资源

1. express.static()

express提供了一个非常好用的函数,叫做express static(),通过它,我们可以非常方便地创建一个静态资源服务器,例如,通过如下代码就可以将public目录下的图片、CSS文件、JavaScript 文件对外开放访问了:


 

现在,你就可以访问public目录中的所有文件了:

http://localhost:3000/images/bg.jpg

http://localhost:3000/css/ style.css

http://localhost:3000/js/login.js

注意:Express 在指定的静态目录中查找文件,并对外提供资源的访问路径。因此,存放静态文件的目录名不会出现在URL中。


2. 托管多个静态资源目录

如果要托管多个静态资源目录,请多次调用express.static() 函数:



 

访问静态资源文件时,express.static() 函数会根据目录的添加顺序查找所需的文件。如果第一个文件夹找到了,则不会找第二个文件夹。




3. 挂载路径前缀

如果希望在托管的静态资源访问路径之前,挂载路径前缀,则可以使用如下的方式:


 

现在,你就可以通过带有 /public 前缀地址来访问public目录中的文件了:

http://localhost:3000/public/images/kitten.jpg

http://localhost:3000/public/css/style.css

http://localhost:3000/public/js/app.js



 


9.4 nodemon

1. 为什么要使用nodemon

在编写调试Node.js项目的时候,如果修改了项目的代码,则需要频繁的手动close掉,然后再重新启动,非常繁琐。

现在,我们可以使用nodemon (https://www.npmjs.com/package/nodemon) 这个工具,它能够监听项目文件的变动,当代码被修改后,nodemon会自动帮我们重启项目,极大方便了开发和调试。
 

2. 安装nodemon

在终端中,运行如下命令,即可将nodemon安装为全局可用的工具:


 


3. 使用nodemon

当基于 Node.js 编写了一个网站应用的时候,传统的方式,是运行 node app.js 命令,来启动项目。这样做的坏处是:代码被修改之后,需要手动重启项目。

现在,我们可以将node命令替换为 nodemon 命令,使用 nodemon app.js 来启动项目。这样做的好处是:代码被修改之后,会被nodemon监听到,从而实现自动重启项目的效果。


 

十、Express路由

10.1 路由的概念

1. 什么是路由

广义上来讲,路由就是映射关系

2. 现实生活中的路由

在这里,路由是按键服务之间的映射关系

3. Express中的路由

在Express中,路由指的是客户端的请求服务器处理函数之间的映射关系

Express中的路由分3部分组成,分别是请求的类型、请求的URL地址、处理函数,格式如下:


 

4. Express中的路由的例子

5. 路由的匹配过程

每当一个请求到达服务器之后,需要先经过路由的匹配,只有匹配成功之后,才会调用对应的处理函数。

在匹配时,会按照路由的顺序进行匹配,如果请求类型请求的URL同时匹配成功,则Express会将这次请求,转交给对应的function函数进行处理。


 

路由匹配的注意点:

①按照定义的先后顺序进行匹配

②请求类型请求的URL同时匹配成功,才会调用对应的处理函数
 

10.2 路由的使用

1. 最简单的用法

在Express中使用路由最简单的方式,就是把路由挂载到app上,示例代码如下:

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

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

IKAnalyzer分词插件使用方法

前言 随着越来越多的大数据网站崛起,特别是一些私人网站都提供了站内搜索,有些人会用elastsearch来实现站内搜索的目的,但是一些小站并没有那么大的数据提供搜索,在安装一个 elastsearch 服务未免有点浪费? 因此&#…

ESB 在零售,物流,制造,保险,医疗行业的应用方式

企业服务总线(Enterprise Service Bus, ESB)是一种基于中间件的集成模式,用于实现不同系统之间的集成与通信。ESB通过标准化接口、消息路由、协议转换和数据转换等功能,帮助企业实现系统间的无缝对接,提高业务敏捷性。…

vcsa6.7-重置root密码

客户反馈vc无法登录了,登录环境一看,报错如下首先想到是证书到期了,浏览器确认,确实是证书到期了准备ssh登录才发现root密码忘记了,那就先重置root密码,1、登录esxi主机找到vcsa6.7机器关机做快照2、开机到…

C++ 赋值与交换法则

在C中,赋值与交换法则(Assignment and Swap Idiom)通常指的是在实现类的赋值操作符(operator)时,结合拷贝构造和交换操作来确保强异常安全保证(Strong Exception Safety Guarantee)的…

Ambari中文汉化

Ambari-ZH 当前Ambari的汉化版本为2.7.4,汉化采用对该版本的ambari源码直接修改的方式进行,如有翻译不当之处,请批评指正 一、使用方法如下: 方式一:直接下载 下载地址:https://github.com/ukayunnuo/Ambari-2.7.x-zh/releases/download/…

表格之固定列和表头

说明 利用粘性定位实现 列固定 td.fixed {position: sticky;left: 0;z-index: 5;/* 最好指定背景&#xff0c;否则滑动时会显示下面的列 */background-color: #f8f9fa; }表头固定 <head><style>.table-container {position: relative;display: flex;overflow: hidd…

React 图标库发布到 npm 仓库

将搭建的 React 图标库发布到 npm 仓库需要经过一系列步骤&#xff0c;包括配置 package.json、构建代码、注册 npm 账号、测试和发布。以下是详细流程&#xff1a; 1. 准备工作 (1) 确保项目结构完整 图标库的典型结构&#xff08;以 Rollup 构建为例&#xff09;&#xff1…

Java学习第八十四部分——HttpClient

目录 一、前言介绍 二、主要特点 三、功能用法 四、应用场景 五、最佳实践 六、总结归纳 一、前言介绍 HttpClient 是一个用于发送 HTTP 请求和接收 HTTP 响应的客户端库&#xff0c;广泛应用于 Web 开发、API 调用、微服务通信等场景。 二、主要特点 支持多种HTTP方…

学习笔记-中华心法问答系统的性能提升

1.简介本周主要任务是自行查找文献&#xff0c;针对源代码进行性能提升&#xff0c;主要包括三个方面&#xff1a;预处理&#xff1a;分词、关键词提取、词向量生成&#xff1b;文本分析&#xff1a;从多个关键词的词向量&#xff0c;如何到一句话的语义理解&#xff1b;问题分…

Python爬虫03_Requests破解百度翻译

爬取百度翻译页面信息 以POST方法发送JSON数据&#xff0c;爬取响应信息&#xff0c;并且需要对响应信息对象类型进行区分。 import requests import json#1.指定url post_url https://fanyi.baidu.com/sug#2.进行UA封装 headers {User-Agent:Mozilla/5.0 (Windows NT 10.0; …

【C++进阶】第8课—红黑树封装map和set

文章目录1. map和set的源码及框架分析2. 模拟实现map和set2.1 实现可以复用红黑树的框架&#xff0c;支持insert操作2.2 实现迭代器iterator2.2.1 实现迭代器2.2.2 实现迭代器 - -2.2.3 解决key不能修改的问题2.2.4 重载operator[ ]3. 完整代码3.1 红黑树头文件RBTree.h3.2 mym…

【机器学习深度学习】DeepSpeed框架:高效分布式训练的开源利器

目录 前言 一、DeepSpeed 简介 1.1 定位与目标 1.2 集成生态 二、核心技术解析 2.1 ZeRO&#xff08;Zero Redundancy Optimizer&#xff09; 2.2 显存优化技术 2.3 推理优化与通信机制 三、DeepSpeed 的优势与特性总结 四、 典型应用场景 &#x1f9e0; 大模型训练…

从视觉到现实:掌握计算机视觉技术学习路线的十大步骤

成长路上不孤单&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;【14后&#x1f60a;///计算机爱好者&#x1f60a;///持续分享所学&#x1f60a;///如有需要欢迎收藏转发///&#x1f60a;】今日分享关于计算机视觉技术学习路线方面的相关内容…

DeepSeek MoE 技术解析:模型架构、通信优化与负载均衡

1. MoE 简介 MoE&#xff08;Mixed Expert Models&#xff09;&#xff0c;混合专家模型。在 Transformer 的 FFN 中&#xff0c;有一个重要的观察是&#xff0c;其计算过程中的神经元激活是非常稀疏的&#xff0c;在一次计算中只有 90%的输入激活不到 5%的神经元&#xff0c;…

【Linux】pthread学习笔记

1. 线程基础(1) 线程创建与终止#include <pthread.h> // 创建线程 int pthread_create(pthread_t *thread, const pthread_attr_t *attr,void *(*start_routine)(void*), void *arg); // 终止当前线程 void pthread_exit(void *retval); // 等待线程结束 int pthread_joi…

p5.js 从零开始创建 3D 模型,createModel入门指南

点赞 关注 收藏 学会了 如果你已经开始探索 p5.js 的 3D 世界&#xff0c;那么createModel()这个 API 绝对是你需要掌握的强大工具。它允许你创建自定义的 3D 几何模型&#xff0c;为你的创意提供无限可能。 什么是 createModel ()&#xff1f; createModel() 用于从一个…

react 的 useTransition 、useDeferredValue

useTransition 用于 管理状态更新的过渡&#xff08;pending&#xff09;状态&#xff0c;避免因高优先级任务&#xff08;如用户输入&#xff09;被低优先级任务&#xff08;如数据获取或复杂计算&#xff09;阻塞而导致的界面卡顿。 它特别适用于&#xff0c;需要 区分紧急更…

Unity的GameObject.Instantiate的使用

在Unity游戏引擎中&#xff0c;GameObject.Instantiate 是一个核心方法&#xff0c;用于在运行时动态创建游戏对象的副本。它常用于实例化预制体&#xff08;Prefab&#xff09;&#xff0c;例如生成敌人、子弹或场景元素。以下是其使用方法的详细说明&#xff0c;包括语法、参…

【CSS】盒子类型

CSS盒子模型是网页布局的核心基础&#xff0c;每个HTML元素都被视为一个矩形盒子&#xff0c;由​​内容&#xff08;Content&#xff09;、内边距&#xff08;Padding&#xff09;、边框&#xff08;Border&#xff09;、外边距&#xff08;Margin&#xff09;​​四部分组成。…

《嵌入式C语言笔记(十五):字符串操作与多维指针深度解析》

1.字符串与指针安全操作核心函数与陷阱函数功能安全替代功能strcpy字符串拷贝strncpy复制前n个&#xff0c;最多strlen个&#xff0c;超出有效长度&#xff0c;按原样复制strcat字符串拼接strncatdest只连接src的前n个&#xff0c;如果n超过有效长度&#xff0c;按原样链接strc…