Dans le développement d'applications Web d'aujourd'hui, Node.js est devenu une option technologique très populaire. Il permet aux développeurs d'écrire du code côté serveur à l'aide de JavaScript et peut gérer des applications hautement concurrentes, en temps réel et gourmandes en données.
Egg.js est un framework de développement web rapide, flexible et évolutif basé sur Node.js. Il est couramment utilisé pour créer des applications Web au niveau de l’entreprise. Egg.js fournit de nombreuses fonctions telles que le routage, le middleware, les plug-ins et le rendu frontal.
Dans cet article, nous expliquerons en détail comment créer une application web à l'aide de Node.js et Egg.js.
Avant de commencer, nous devons d'abord installer Node.js et Egg.js. Vous pouvez télécharger le package d'installation sur le site officiel ou l'installer à l'aide du gestionnaire de packages npm de Node.js.
Egg.js dépend de l'environnement d'exécution de Node.js, vous devez donc vous assurer que Node.js a été correctement installé.
Pour installer Egg.js, exécutez simplement la commande suivante dans une fenêtre de terminal :
npm install egg --save
Après avoir installé Egg.js, nous pouvons utiliser la commande suivante pour créer une nouvelle application Egg.js :
npx egg-init my-egg-app --type=simple
Cette commande créera une nouvelle application Egg.js, où mon -egg-app
est le nom de votre application et --type=simple
signifie que nous créons une simple application Egg.js. my-egg-app
是您的应用程序名称,--type=simple
表示我们正在创建一个简单的Egg.js应用程序。
在创建Egg.js应用程序后,我们需要配置应用程序以确保其正确运行。
配置文件config/config.default.js
是Egg.js应用程序的默认配置文件。我们可以通过修改配置来更改应用程序的默认行为。
例如,在配置文件中可以设置应用程序运行的端口号。我们可以将其更改为3000,这是一个常见的HTTP应用程序端口号:
// config/config.default.js exports.keys = 'my_secret_key'; exports.cluster = { listen: { port: 3000, } };
此外,我们还可以使用配置文件中的插件来添加一些功能。例如,如果我们需要将请求转发到其他服务,则可以添加一个代理插件egg-http-proxy
。
这里是如何添加egg-http-proxy
插件的示例代码:
// config/plugin.js exports.httpProxy = { enable: true, package: 'egg-http-proxy', };
然后在配置文件config/config.default.js
中使用httpProxy
插件并进行设置:
// config/config.default.js exports.httpProxy = { '/api': { target: 'http://127.0.0.1:7001', changeOrigin: true, rewrite: (path) => path.replace(/^/api/, ''), }, };
这个配置代码将所有以/api
开头的请求转发到本地端口号为7001的服务上。同时,changeOrigin
选项将会将HTTP请求中的host
头替换为目标URL中的主机名,rewrite
选项将会将请求路径重写为不包含/api
前缀的URL。
Egg.js的MVC框架包括了控制器、模型以及视图。我们可以通过编写控制器和路由来处理HTTP请求,并返回响应结果。
控制器位于app/controller
目录下,我们可以创建一个新的控制器来处理HTTP请求。例如,我们可以创建一个名为home.js
的控制器,并在其中定义一个index
方法:
// app/controller/home.js const Controller = require('egg').Controller; class HomeController extends Controller { async index() { const { ctx } = this; ctx.body = 'Hello World'; } } module.exports = HomeController;
现在我们需要为这个控制器添加一个路由。我们可以在app/router.js
文件中定义路由:
// app/router.js module.exports = (app) => { const { router, controller } = app; router.get('/', controller.home.index); };
在这里,我们为根URL路径定义了一个路由,并将其与HomeController
的index
Le fichier de configuration config/config.default.js
est le fichier de configuration par défaut de l'application Egg.js. Nous pouvons changer le comportement par défaut de l'application en modifiant la configuration.
Par exemple, le numéro de port de l'application à exécuter peut être défini dans le fichier de configuration. Nous pouvons le changer en 3000, qui est un numéro de port d'application HTTP courant :
npm start
egg-http-proxy
. egg-http-proxy
: Puis dans le fichier de configuration config /config.default Utilisez le plug-in <code>httpProxy
dans .js et configurez-le :
Ce code de configuration transmettra toutes les requêtes commençant par /api
vers Sur le service avec le numéro de port local 7001. Dans le même temps, l'option changeOrigin
remplacera l'en-tête host
dans la requête HTTP par le nom d'hôte dans l'URL cible, et le rewrite
L'option remplacera le chemin de la requête. Réécrire vers une URL qui ne contient pas le préfixe /api
.
app/controller
Nous pouvons créer un nouveau contrôleur pour gérer les requêtes HTTP. Par exemple, nous pouvons créer un contrôleur nommé home.js
et y définir une méthode index
: #🎜🎜#rrreee#🎜🎜#Maintenant, nous devons Ce contrôleur ajoute un itinéraire. Nous pouvons définir des routes dans le fichier app/router.js
: #🎜🎜#rrreee#🎜🎜#Ici, nous définissons une route pour le chemin de l'URL racine et la connectons au HomeController La méthode <code>index
de code> est liée. #🎜🎜##🎜🎜##🎜🎜#Exécutez l'application Egg.js #🎜🎜##🎜🎜##🎜🎜#Enfin, nous pouvons utiliser la commande suivante pour démarrer l'application Egg.js : #🎜🎜# rrreee #🎜🎜#Cette commande démarrera l'application Egg.js et écoutera les demandes du client. #🎜🎜##🎜🎜##🎜🎜#Conclusion#🎜🎜##🎜🎜##🎜🎜#Dans cet article, nous avons appris à créer une application Web à l'aide de Node.js et Egg.js. Nous avons appris à installer Node.js et Egg.js, à créer une application Egg.js, à configurer une application Egg.js, à écrire des contrôleurs et des routes et à exécuter une application Egg.js. #🎜🎜##🎜🎜#Egg.js est un puissant framework de développement Web qui fournit de nombreuses fonctionnalités pour aider les développeurs à créer des applications Web efficaces, évolutives et faciles à entretenir. Si vous recherchez un framework Node.js fiable et puissant, Egg.js pourrait être un bon choix. #🎜🎜#
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!