> 웹 프론트엔드 > JS 튜토리얼 > Node의 Express 및 라우팅 모듈을 자세히 설명하는 기사

Node의 Express 및 라우팅 모듈을 자세히 설명하는 기사

青灯夜游
풀어 주다: 2023-01-27 05:30:01
앞으로
2064명이 탐색했습니다.

이 기사에서는 Node를 함께 배우고 Express 및 라우팅 모듈 사용에 대해 심층적으로 소개할 것입니다. 도움이 되기를 바랍니다.

Node의 Express 및 라우팅 모듈을 자세히 설명하는 기사

Express

Express는 빠르고 개방적이며 미니멀한 웹 개발 프레임워크인 Node.js 플랫폼을 기반으로 합니다. Express의 기능은 웹 서버를 만드는 데 특별히 사용되는 Node.js에 내장된 http 모듈과 유사합니다. Express의 본질: 웹 서버를 빠르게 생성하는 편리한 방법을 제공하는 npm의 타사 패키지입니다. 중국 웹사이트는 Express Chinese 웹사이트입니다. 물론, Express를 사용하지 않고도 내장된 http 모듈을 이용하여 웹 서버를 만들 수는 있지만, http 모듈은 사용이 매우 복잡하고 개발 효율도 매우 낮습니다. 이는 개발 효율성을 크게 향상시킬 수 있습니다. 프런트 엔드 프로그래머의 경우 가장 일반적인 두 가지 서버는 웹 웹 사이트 서버

(외부 웹 페이지 리소스 제공 전용 서버) API 인터페이스 서버(전용 외부 API 인터페이스 서버)입니다. Express를 사용하면 웹 웹사이트 서버와 API 인터페이스 서버를 빠르고 쉽게 만들 수 있습니다. [관련 튜토리얼 권장 사항: nodejs 비디오 튜토리얼, Programming Teaching] Express 설치 및 사용

프로젝트가 있는 디렉터리에서 터미널에서 다음 명령을 실행하여 프로젝트에 Express를 설치합니다. (기본 최신 버전)
npm install express
로그인 후 복사

기본 서버 만들기

: http 모듈이 내장된 일반 서버와 비교 http 내장 모듈 작성

// 导入 express 模块
const express = require('express')
// 创建 web 服务器
const app = express()

// 调用 app.listen(端口号,启动成功后的回调函数),启动服务器
app.listen(8081,()=>{
  console.log('express server running at http://127.0.0.1:8081');
})
로그인 후 복사
GET 요청 듣기

: 앱을 통해 .get() 메소드를 사용하면 클라이언트의 GET 요청을 수신할 수 있으며 구체적인 구문 형식은 다음과 같습니다.

// 参数1:客户端请求的URL地址
// 参数2:请求对应的处理函数
// req:请求对象(包含请求相关属性和方法);res:响应对象(包含响应相关的属性和方法)
app.get('请求的URL',function(req,res){/*处理函数*/})
로그인 후 복사
POST 요청 모니터링

: app.post() 메소드를 통해 클라이언트의 POST 요청을 모니터링할 수 있습니다. 구체적인 구문 형식은 다음과 같습니다.

// 参数1:客户端请求的URL地址
// 参数2:请求对应的处理函数. req:请求对象(包含请求相关属性和方法);res:响应对象(包含响应相关的属性和方法)
app.post('请求的URL',function(req,res){/*处理函数*/})
로그인 후 복사
Create with get 및 post로 요청한 웹 서버가 성공적으로 생성되었으며 Apifox 인터페이스 테스트 도구로 테스트되었습니다.
// 导入 express 模块
const express = require('express')

// 创建 Web 服务器
const app = express()

// get请求
app.get('/user',(req,res)=>{
  // 向客户端响应一个 json 对象
  res.send({name:'张三',age:18})
})

// post请求
app.post('/home',(req,res)=>{
  // 向客户端响应一个 文本字符串
  res.send('请求成功!')
}) 

app.listen(80,()=>{
  console.log('express server running at http://127.0.0.1:80');
})
로그인 후 복사

URL의 쿼리 매개변수를 가져옵니다. req.query 객체를 통해 쿼리 문자열 형식으로 클라이언트에 액세스할 수 있습니다. 서버로 전송되는 매개변수:

app.get('/',(req,res)=>{
  // 通过 req.query 可以获取到客户端发送过来的查询参数,默认情况下,req.query 是一个空对象
  console.log(req.query);
  res.send(req.query)
})
로그인 후 복사

URL에서 동적 매개변수를 얻습니다. req.params 객체를 통해 다음을 통해 URL에 액세스할 수 있습니다. 일치하는 동적 매개변수:

// 这里的id是一个动态参数
app.get('/user/:id',(req,res)=>{
  // req.params 是动态匹配到的 URL 参数,默认也是一个空对象
  console.log(req.params);
  res.send(req.params)
})
로그인 후 복사

Hosting Static resources

express는 express.static()이라는 매우 유용한 기능을 제공합니다. 이를 통해 정적 리소스 서버를 쉽게 만들 수 있습니다. 다음 코드를 통해 테스트 디렉터리에 이미지와 CSS를 추가하는 코드를 사용할 수 있습니다. 파일과 JS 파일은 외부 개발에 사용되며 http://127.0.0.1/index.htm을 통해 액세스할 수 있습니다. 여러 정적 리소스 디렉터리를 호스팅하려면 express.static() 함수를 여러 번 호출하면 됩니다.

app.use(express.static('test'))
로그인 후 복사

Note

: ​​Express는 지정된 정적 디렉터리에서 파일을 찾아 외부적으로 리소스에 대한 액세스 경로를 제공하므로 정적 리소스의 디렉터리 이름이 URL에 표시되지 않습니다. 정적 리소스 액세스 경로를 호스팅하기 전에 경로 접두사를 마운트하려면 다음 방법을 사용할 수 있습니다.

// 在 express.static() 方法前面添加想要的路径前缀
app.use('text',express.static('test'))
로그인 후 복사

nodemon

在编写调试Node.js项目时,如果修改了项目代码,则需要手动频繁的close掉,然后重新启动非常的繁琐。我们可以使用 nodemon 这个工具,它能够监听项目文件的变动,当代码修改后,nodemon会自动帮助我们重启项目,极大地方便了开发与测试。

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

npm install nodemon -g
로그인 후 복사

安装完成之后,将之前的命令 node+文件名称 换成 nodemon+文件名称 即可自动重启项目进行监听,如下:

Express路由

在Express中,路由指的是客户端的请求与服务器之间的映射关系。Express中的路由分三部分组成:请求的类型、请求的URL地址、处理函数。

每当一个请求到达服务器之后,需要先经过路由的匹配,只有匹配成功之后,才会调用对应的处理函数。在匹配时,会按照路由的顺序进行匹配,如果请求类型和请求的URL同时匹配成功,则Express会将这次请求转交到对应的function函数进行处理。

// 导入 express 模块
const express = require('express')
// 创建 Web 服务器
const app = express()
// 挂载路由
app.get('/',(req,res)=>{ res.send('hello world'); })
app.post('/',(req,res)=>{ res.send('hello ok'); })

// 监听服务
app.listen(80,()=>{
  console.log('express server running at http://127.0.0.1');
})
로그인 후 복사
로그인 후 복사

模块化路由

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

创建路由模块:

// 导入 express 模块
const express = require('express')
// 创建 Web 服务器
const app = express()
// 挂载路由
app.get('/',(req,res)=>{ res.send('hello world'); })
app.post('/',(req,res)=>{ res.send('hello ok'); })

// 监听服务
app.listen(80,()=>{
  console.log('express server running at http://127.0.0.1');
})
로그인 후 복사
로그인 후 복사

注册路由模块:

// 导入 express 模块
const express = require('express')
// 创建 服务器
const app = express()

// 导入路由模块
const router = require('./router')
// 注册路由模块
app.use(router)

// 监听服务
app.listen(80,()=>{
  console.log('express server running at http://127.0.0.1');
})
로그인 후 복사

如果想为路由模块添加前缀,方式也很简单,如下:(即可全局模块路径前有该前缀)

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

위 내용은 Node의 Express 및 라우팅 모듈을 자세히 설명하는 기사의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:csdn.net
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿