Heim  >  Artikel  >  Web-Frontend  >  Ein Artikel, in dem die Express- und Routing-Module in Node ausführlich erläutert werden

Ein Artikel, in dem die Express- und Routing-Module in Node ausführlich erläutert werden

青灯夜游
青灯夜游nach vorne
2023-01-27 05:30:011942Durchsuche

Dieser Artikel führt Sie gemeinsam in das Erlernen von Node ein und gibt eine ausführliche Einführung in die Verwendung von Express- und Routing-Modulen. Ich hoffe, er wird Ihnen hilfreich sein!

Ein Artikel, in dem die Express- und Routing-Module in Node ausführlich erläutert werden

Express

Express basiert auf der Node.js-Plattform, einem schnellen, offenen und minimalistischen Webentwicklungs-Framework. Die Funktion von Express ähnelt dem integrierten http-Modul von Node.js, das speziell zum Erstellen von Webservern verwendet wird. Die Essenz von Express: Es handelt sich um ein Drittanbieterpaket auf npm, das eine bequeme Möglichkeit bietet, schnell einen Webserver zu erstellen. Die chinesische Website lautet: Express Chinese website. Natürlich können Sie einen Webserver mit dem integrierten http-Modul erstellen, ohne Express zu verwenden, aber die Verwendung des http-Moduls ist äußerst kompliziert und die Entwicklungseffizienz ist äußerst gering. Express basiert weiter auf dem integrierten http-Modul. Dies kann die Entwicklungseffizienz erheblich verbessern. Für Front-End-Programmierer sind die beiden häufigsten Server: Web-Website-Server

(ein Server, der speziell externe Webseitenressourcen bereitstellt); API-Schnittstellenserver (ein dedizierter externer API-Schnittstellenserver). Mit Express können Sie schnell und einfach einen Webserver und einen API-Schnittstellenserver erstellen. [Verwandte Tutorial-Empfehlungen: nodejs-Video-Tutorial, Programmierlehre] Installation und Verwendung von Express

Führen Sie im Verzeichnis, in dem sich das Projekt befindet, den folgenden Befehl auf dem Terminal aus, um Express im Projekt zu installieren: (Standardneueste Version)
npm install express

Erstellen Sie einen Basisserver

: Vergleichen Sie ihn mit herkömmlichen Servern mit integriertem http-Modul. http-integriertes Schreiben mit Modulen.

// 导入 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');
})
Hören Sie sich GET-Anfragen an.

: Über die App Mit der Methode .get() können Sie die GET-Anfrage des Clients abhören. Das spezifische Syntaxformat lautet wie folgt:

// 参数1:客户端请求的URL地址
// 参数2:请求对应的处理函数
// req:请求对象(包含请求相关属性和方法);res:响应对象(包含响应相关的属性和方法)
app.get('请求的URL',function(req,res){/*处理函数*/})
Überwachen von POST-Anfragen

: Mit der Methode app.post() können Sie die POST-Anfrage des Clients überwachen. Das spezifische Syntaxformat lautet wie folgt:

// 参数1:客户端请求的URL地址
// 参数2:请求对应的处理函数. req:请求对象(包含请求相关属性和方法);res:响应对象(包含响应相关的属性和方法)
app.post('请求的URL',function(req,res){/*处理函数*/})
Erstellen mit get und Der per Post angeforderte Webserver wurde erfolgreich erstellt und mit dem Apifox-Schnittstellentesttool getestet:
// 导入 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');
})

Rufen Sie die Abfrageparameter der URL ab: Über das req.query-Objekt können Sie in Form einer Abfragezeichenfolge auf den Client zugreifen. An den Server gesendete Parameter:

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

Erhalten Sie dynamische Parameter in der URL: Über das req.params-Objekt können Sie können auf die URL zugreifen über: Übereinstimmende dynamische Parameter:

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

Hosten statischer Ressourcen

express bietet eine sehr nützliche Funktion namens express.static(), mit der wir ganz einfach einen statischen Ressourcenserver erstellen können. Mit dem folgenden Code können wir Bilder und CSS zum Testverzeichnis hinzufügen. Dateien und JS-Dateien werden für die externe Entwicklung verwendet, und wir können über http://127.0.0.1/index.htm darauf zugreifen. Wenn Sie mehrere statische Ressourcenverzeichnisse hosten möchten, rufen Sie einfach die Funktion express.static() mehrmals auf.

app.use(express.static('test'))

Hinweis

: Express sucht nach Dateien im angegebenen statischen Verzeichnis und stellt Zugriffspfade auf Ressourcen extern bereit, sodass die Verzeichnisnamen statischer Ressourcen nicht in der URL angezeigt werden. Wenn Sie das Pfadpräfix vor dem Hosten des statischen Ressourcenzugriffspfads bereitstellen möchten, können Sie die folgende Methode verwenden:

// 在 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 教程

Das obige ist der detaillierte Inhalt vonEin Artikel, in dem die Express- und Routing-Module in Node ausführlich erläutert werden. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:csdn.net. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen