>웹 프론트엔드 >JS 튜토리얼 >node.js의 익스프레스 라우팅에 대한 심층 분석

node.js의 익스프레스 라우팅에 대한 심층 분석

青灯夜游
青灯夜游앞으로
2022-01-07 20:00:072339검색

이 글은 node의 Express 라우팅을 이해하고 기본적인 사용법을 소개하는 글입니다. 모든 분들께 도움이 되길 바랍니다!

node.js의 익스프레스 라우팅에 대한 심층 분석

1. 라우팅의 개념

1.1 라우팅이란

넓은 의미에서 라우팅은 매핑 관계입니다.

실생활에서

node.js의 익스프레스 라우팅에 대한 심층 분석

按键 1  ->  业务查询
按键 2  ->  手机充值
按键 3  ->  业务办理
按键 4  ->  密码服务与停复机
按键 5  ->  家庭宽带
按键 6  ->  话费流量
按键 8  ->  集团业务
按键 0  ->  人工服务

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

1.2 nodejs의 라우팅

routing in nodejs은 실제로 URL 주소와 응답 기능 간의 매핑 관계입니다.

경로 일치 관계의 업무를 별도의 js 파일로 추출하는 것입니다.

2.Express

2.1 Express 소개

Node.js 플랫폼을 기반으로 빠르고 개방적이며 미니멀리스트 웹 개발 프레임워크

  • express 공식 웹사이트 (http://expressjs.com/)
  • express 중국어 웹사이트 (http://expressjs.com.cn/)

1. Node.js 내장 http 모듈은 유사하며 특히 웹 서버를 만드는 데 사용됩니다.
2. Express의 본질: 웹 서버를 빠르게 생성할 수 있는 편리한 방법을 제공하는 npm의 타사 패키지입니다.

express에 대해 자세히 알아보기

생각: Express를 사용하지 않고 웹 서버를 만들 수 있습니까?
답변: 예, Node.js에서 제공하는 기본 http 모듈을 사용하세요.

생각하기: 이미 좋은데 어떻게 밝을 수 있습니까(http 내장 모듈이 있는데 왜 아직도 Express를 사용합니까)?
답변: 내장 http 모듈은 사용하기가 매우 복잡하고 개발 효율성이 낮습니다. Express는 내장 http 모듈을 기반으로 더욱 캡슐화되어 개발 효율성을 크게 향상시킬 수 있습니다.

생각하기: http 내장 모듈과 Express 사이에는 어떤 관계가 있나요?
답변: 브라우저에서 Web API와 jQuery의 관계와 유사합니다. 후자는 전자를 기반으로 추가로 캡슐화됩니다.

2.2 기본 사용 단계

  • 설치: npm i expressnpm i express
// 导入 express
var express = require('express');
// 创建 express实例,也就是创建 express服务器
var app = express();


// 启动服务器
app.listen(3000, function () {
  console.log('服务器已启动')
})

监听get请求

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

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-wu5WkyIV-1639963661922)(images3/image-2020052923160665node.js의 익스프레스 라우팅에 대한 심층 분석)]

监听post请求

通过 app.post()

// 最新的express版本,不再需要body-parse的下载支持了,直接按如下的方式来书写即可 
app.use(express.urlencoded({ extended: true }))
app.post('/index',(req,res)=>{
  console.log(req.body);
})

요청 받기

app.get()를 통해 받기 > 방법을 사용하면 클라이언트의 GET 요청을 모니터링할 수 있습니다.

[외부 링크 이미지 전송에 실패했습니다. 소스 사이트에 안티 리칭 메커니즘이 있을 수 있습니다. 이미지를 저장하고 직접 업로드하는 것이 좋습니다. (img-wu5WkyIV-1639963661922) (images3/ image-2020052923160665node.js의 익스프레스 라우팅에 대한 심층 분석)]

포스트 요청 모니터링

app.post() 메소드를 통해 클라이언트의 POST 요청을 모니터링할 수 있습니다. 구체적인 구문 형식은 다음과 같습니다. [외부 링크 사진 전송에 실패했습니다. 소스 사이트에 리칭 방지 메커니즘이 있을 수 있습니다. 이미지를 저장하고 직접 업로드하는 것이 좋습니다(img-wzB8FFER-1639963661923) (images3/ image-20200529231710830.png)]

res를 통해 클라이언트에 대한 응답 콘텐츠

send() 메소드는 처리된 콘텐츠를 클라이언트에 보낼 수 있습니다.

[외부 링크 이미지 전송에 실패했을 수 있습니다. 이미지를 저장하고 직접 업로드하는 것이 좋습니다(img-Iiifw7XV-1639963661924)(image3/image-20200529231837638.png)]

2.3 req 속성에 대한 자세한 설명req.query 객체를 통해 클라이언트가 GET 메소드를 통해 서버로 보낸 매개변수를 가져올 수 있습니다.예: http://127.0.0.1:3000/index?id =10&name=tom&age=20[외부 링크 이미지 전송에 실패했습니다. 소스 사이트에 리칭 방지 메커니즘이 있을 수 있습니다. 이미지를 저장하고 직접 업로드하는 것이 좋습니다(img-WUoF7b2h-1639963661925)(images3/image- 20200529231928577.png)]req.params
Get get 요청의 매개변수
Name Function
req.query

Get 요청으로 전달된 매개변수 가져오기 및 개체 가져오기
req .body 데이터 전달 받기 Post 요청으로 얻는 것은 객체입니다. 미들웨어를 등록해야 합니다
Get 요청에서 라우팅 매개변수를 가져옵니다. 예: jd.com/32342545365 🎜app.get('/product/:id')🎜🎜🎜🎜req.get(key)🎜🎜요청 헤더의 지정된 키에 해당하는 값을 가져옵니다🎜🎜🎜🎜

获取post请求的参数

通过req.body可以获取post请求的参数,但是需要配合body-parser中间件

不再需要使用req.on(‘data’,chunk=>{})         req.on(‘end’,()=>{})

如果没有这个中间件的话,则默认获取的是undefined.

// 最新的express版本,不再需要body-parse的下载支持了,直接按如下的方式来书写即可 
app.use(express.urlencoded({ extended: true }))
app.post('/index',(req,res)=>{
  console.log(req.body);
})

2.4 res属性详解

// send() 发送数据给客户端,并自动设置Content-Type
res.send()  //用于向浏览器客户端响应数据 会自带合适的响应头

// 发送文件给浏览器,并根据文件后缀名自动设置Content-Type
// 注意:文件路径必须是绝对路径
res.sendFile(path.join(__dirname, 'index.html'))

// 设置响应头
res.set('Content-Type', 'text/plain')
res.set({
  'Content-Type': 'text/plain',
  'cute': 'fangfang'
})

// 重定向 
res.redirect('/index')
方法 作用
res.send() 响应给客户端浏览器的数据,会自带响应头
send方法在将上面的对象数据响应给浏览器的时候,相当于内部会调用 JSON.stringify()
res.sendFile(path) 响应给浏览器一个页面
res.redirect() 重定向 会自带状态码
res.set(key,value) 自定义响应头
res.status() 设置响应状态码

2.5 express路由处理

基本使用

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-D3rId34r-1639963661925)(images3/image-20200529233016669.png)]

  • app.get(path, callback)
  • app.post(path, callback)
  • app.use(path, callback) 更重要的作用是处理中间件
    • 注意:只要是以path开头的请求地址,都可以被use处理
    • 注意:可以处理任意的请求类型
    • 注意:path参数可省略,默认值为:/
// all可以匹配任何提交方式 get和post都可以
app.all('*',(req,res)=>{
 // 做一个其它比较友好界面 响应给浏览器
  res.send('页面还没完成,请等待...')
})

路由的匹配过程

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

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

node.js의 익스프레스 라우팅에 대한 심층 분석

路由匹配的注意点:

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

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

全局挂载路由

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

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pdjsILgz-1639963661927)(images3/image-2020052923325460node.js의 익스프레스 라우팅에 대한 심층 분석)]

2.6 模块化路由

        为了方便对路由进行模块化的管理,Express 不建议将路由直接挂载到 app 上,而是推荐将路由抽离为单独的模块。

将路由抽离为单独模块的步骤如下:

①创建路由模块对应的 .js 文件 router.js

②调用 express.Router() 函数创建路由对象

③向路由对象上挂载具体的路由

④使用 module.exports 向外共享路由对象

⑤使用 app.use() 函数注册路由模块

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-3fEDx0H3-1639963661928)(images3/image-2020052923332450node.js의 익스프레스 라우팅에 대한 심층 분석)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-QAUKjV4x-1639963661931)(images3/image-20200529233330060.png)]

2.7 静态资源处理

基本使用

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

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-C1BTBqzr-1639963661933)(images3/image-2020052923240715node.js의 익스프레스 라우팅에 대한 심층 분석)]

现在,你就可以访问 public 目录中的所有文件了:
http://localhost:3000/images/bg.jpg
http://localhost:3000/css/style.css
http://localhost:3000/js/login.js

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

托管多个资源目录

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

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Px6ZUuaQ-1639963661934)(images3/image-20200529232555610.png)]

上面的设置需要注意的是:在html页面中的那些静态资源路径一定不要在出现public

访问静态资源文件时,express.static() 函数会根据目录的添加顺序查找所需的文件。

挂载路径前缀

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

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-e13liOYs-1639963661934)(images3/image-2020052923262669node.js의 익스프레스 라우팅에 대한 심층 분석)]

现在,你就可以通过带有 /public 前缀地址来访问 public 目录中的文件了:
http://localhost:3000/public/images/kitten.jpg
http://localhost:3000/public/css/style.css
http://localhost:3000/public/js/app.js

2.8 express中间件

什么是中间件

中间件(Middleware )其实就是一个函数,特指业务流程的中间处理环节。

分为全局中间件和路由中间件。

中间件分为两种 一个是全局中间件 一个是路由中间件

现实生活中的例子

node.js의 익스프레스 라우팅에 대한 심층 분석

处理污水的这中间处理环节,就可以叫做中间件。

express中的中间件

当一个请求到达 Express 的服务器之后,可以连续调用多个中间件,从而对这次请求进行预处理。

node.js의 익스프레스 라우팅에 대한 심층 분석

基本使用

Express 的中间件,本质上就是一个 function 处理函数,Express 中间件的格式如下:

const mw = function(req, res, next) {
  next()
}
app.use(mw)

注意:中间件函数的形参列表中,必须包含 next 参数。而路由处理函数中只包含 req 和 res。

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

node.js의 익스프레스 라우팅에 대한 심층 분석

中间件的作用

多个中间件之间,共享同一份 req res。基于这样的特性,我们可以在上游的中间件中,统一为 req 或 res 对象添加自定义的属性或方法,供下游的中间件或路由进行使用。

node.js의 익스프레스 라우팅에 대한 심층 분석

定义多个中间件

可以使用 app.use() 连续定义多个全局中间件。客户端请求到达服务器之后,会按照中间件定义的先后顺序依次进行调用,示例代码如下:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-s5pYXD4F-1639963661937)(images3/image-2020052923390169node.js의 익스프레스 라우팅에 대한 심층 분석)]

express内置中间件

自 Express 4.16.0 版本开始,Express 内置了 3 个常用的中间件,极大的提高了 Express 项目的开发效率和体验:

① express.static 快速托管静态资源的内置中间件,例如: HTML 文件、图片、CSS 样式等(无兼容性)

② express.json 解析 JSON 格式的请求体数据(有兼容性,仅在 4.16.0+ 版本中可用)

③ express.urlencoded 解析 URL-encoded 格式的请求体数据(有兼容性,仅在 4.16.0+ 版本中可用)

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-WJaSINca-1639963661937)(images3/image-20200529234155137.png)]

3.EJS模板

3.1 ejs介绍

ejs是一个高效的javascript模板引擎,是为了使用户页面与业务数据(分离)而产生的。

简单来说,使用ejs模板引擎就可以帮助我们快速的将数据渲染到页面对应的位置,和art-template模板类似.

3.2 ejs的使用

1.下载

npm i ejs

2.配置模板引擎

app.set('view engine','ejs')

3.配置模板的存放目录

app.set('views','./views')   //默认的是可以省略

4.在views目录下创建模板文件    views文件夹中的静态页面此时应该修改后缀.ejs

5.使用模板渲染数据

res.render('index',obj)
//第一个参数就是要渲染的页面,直接写名称不用加后缀
//第二个参数表示待渲染的对象,通常是一个对象

3.3 数据渲染

     写业务逻辑

   在某位置输出数据

    不转义输出

更多node相关知识,请访问:nodejs 教程!!

위 내용은 node.js의 익스프레스 라우팅에 대한 심층 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 juejin.cn에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제