Heim > Datenbank > MongoDB > So entwickeln Sie eine einfache CRUD-API mit MongoDB

So entwickeln Sie eine einfache CRUD-API mit MongoDB

王林
Freigeben: 2023-09-19 12:32:00
Original
1123 Leute haben es durchsucht

如何使用MongoDB开发一个简单的 CRUD API

So entwickeln Sie eine einfache CRUD-API mit MongoDB

In der modernen Webanwendungsentwicklung sind CRUD-Operationen (Erstellen, Löschen, Ändern, Überprüfen) eine der sehr häufigen und wichtigen Funktionen. In diesem Artikel stellen wir die Entwicklung einer einfachen CRUD-API mithilfe der MongoDB-Datenbank vor und stellen spezifische Codebeispiele bereit.

MongoDB ist eine Open-Source-NoSQL-Datenbank, die Daten in Form von Dokumenten speichert. Im Gegensatz zu herkömmlichen relationalen Datenbanken verfügt MongoDB über kein vordefiniertes Schema, was die Datenspeicherung und -abfrage flexibler macht. Daher eignet sich MongoDB ideal zum Speichern und Verarbeiten großer Mengen unstrukturierter Daten.

Bevor wir die CRUD-API entwickeln, müssen wir sicherstellen, dass MongoDB korrekt installiert und konfiguriert wurde. Sie können die neueste Version von MongoDB von der offiziellen MongoDB-Website herunterladen, installieren und gemäß der offiziellen Anleitung konfigurieren.

Als nächstes werden wir unsere CRUD-API mit Node.js und Express.js entwickeln. Stellen Sie sicher, dass Sie Node.js installiert haben und mit der grundlegenden Node.js- und Express.js-Entwicklung vertraut sind. Fangen wir an!

Schritt eins: Projektinitialisierung
Erstellen Sie zunächst ein neues Node.js-Projekt und initialisieren Sie die Datei package.json. Führen Sie den folgenden Befehl in der Befehlszeile aus:

$ mkdir crud-api
$ cd crud-api
$ npm init -y
Nach dem Login kopieren

Dadurch wird ein neues Verzeichnis mit dem Namen crud-api erstellt und darin ein neues Node.js-Projekt initialisiert. Die Option -y erstellt eine Datei package.json mit Standardeinstellungen. crud-api的新目录,并在其中初始化一个新的Node.js项目。-y选项将使用默认设置创建package.json文件。

第二步:安装依赖项
我们将使用一些npm包来帮助我们开发CRUD API。在命令行中执行以下命令来安装依赖项:

$ npm install express body-parser mongoose
Nach dem Login kopieren

这会使用npm安装expressbody-parsermongoose三个包。express是一个流行的Node.js框架,body-parser是一个解析请求体的中间件,mongoose是用于与MongoDB数据库交互的对象模型工具。

第三步:创建服务器和路由
在项目的根目录下,创建server.js文件,并添加以下代码:

const express = require('express');
const bodyParser = require('body-parser');
const mongoose = require('mongoose');

const app = express();
const port = 3000;

// 连接MongoDB数据库
mongoose.connect('mongodb://localhost:27017/crud-api', { useNewUrlParser: true });
const db = mongoose.connection;
db.on('error', console.error.bind(console, '数据库连接失败:'));
db.once('open', () => {
  console.log('数据库连接成功!');
});

// 设置路由
app.use(bodyParser.urlencoded({ extended: true }));
app.use(bodyParser.json());

app.get('/', (req, res) => {
  res.send('欢迎使用CRUD API');
});

// 启动服务器
app.listen(port, () => {
  console.log('服务器已启动,端口号:' + port);
});
Nach dem Login kopieren

这段代码首先引入所需的npm包,然后创建一个Express应用程序并设置服务器端口为3000。之后,我们使用mongoose.connect()方法连接到MongoDB数据库。请确保MongoDB服务运行在本地机器的默认端口27017上。接下来,我们设置了一个主要用于测试的根路由。最后,我们使用app.listen()方法启动服务器并监听3000端口。

第四步:定义模型和路由
我们将创建一个名为product的简单数据库模型,并编写对应的CRUD路由。在server.js文件中添加以下代码:

const Product = require('./models/product');

// 查询所有产品
app.get('/api/products', (req, res) => {
  Product.find({}, (err, products) => {
    if (err) {
      res.status(500).send('查询数据库出错!');
    } else {
      res.json(products);
    }
  });
});

// 查询单个产品
app.get('/api/products/:id', (req, res) => {
  Product.findById(req.params.id, (err, product) => {
    if (err) {
      res.status(500).send('查询数据库出错!');
    } else if (!product) {
      res.status(404).send('找不到产品!');
    } else {
      res.json(product);
    }
  });
});

// 创建新产品
app.post('/api/products', (req, res) => {
  const newProduct = new Product(req.body);
  newProduct.save((err, product) => {
    if (err) {
      res.status(500).send('保存到数据库出错!');
    } else {
      res.json(product);
    }
  });
});

// 更新产品
app.put('/api/products/:id', (req, res) => {
  Product.findByIdAndUpdate(req.params.id, req.body, { new: true }, (err, product) => {
    if (err) {
      res.status(500).send('更新数据库出错!');
    } else if (!product) {
      res.status(404).send('找不到产品!');
    } else {
      res.json(product);
    }
  });
});

// 删除产品
app.delete('/api/products/:id', (req, res) => {
  Product.findByIdAndRemove(req.params.id, (err, product) => {
    if (err) {
      res.status(500).send('删除数据库出错!');
    } else if (!product) {
      res.status(404).send('找不到产品!');
    } else {
      res.send('产品删除成功!');
    }
  });
});
Nach dem Login kopieren

在这段代码中,我们首先引入Product模型,该模型是一个基于mongoose.Schema的简单MongoDB模型。然后,我们定义了用于查询所有产品、查询单个产品、创建新产品、更新产品和删除产品的路由。在每个路由中,我们都使用相应的mongoose方法来与MongoDB数据库交互,并根据返回结果发送合适的响应。

第五步:定义模型
在项目的根目录下,创建一个models目录并在其中创建product.js文件。在product.js文件中添加以下代码:

const mongoose = require('mongoose');

const productSchema = new mongoose.Schema({
  name: String,
  price: Number,
  description: String
});

const Product = mongoose.model('Product', productSchema);

module.exports = Product;
Nach dem Login kopieren

这段代码定义了一个简单的产品模型Product,它有一个名为name的字符串属性,一个名为price的数字属性和一个名为description的字符串属性。将productSchema模型作为参数传递给mongoose.model()方法并导出Product

第六步:运行服务器
在项目的根目录下,通过以下命令来运行服务器:

$ node server.js
Nach dem Login kopieren

如果一切顺利,你将会在命令行中看到成功连接到数据库和服务器已启动的消息。现在,你可以在浏览器或Postman中访问API的不同路由,如:http://localhost:3000/api/products

Schritt 2: Abhängigkeiten installieren

Wir werden einige npm-Pakete verwenden, um uns bei der Entwicklung der CRUD-API zu helfen. Führen Sie den folgenden Befehl in der Befehlszeile aus, um Abhängigkeiten zu installieren:
rrreee

Dadurch werden npm verwendet, um express, body-parser und mongoose Bag zu installieren . express ist ein beliebtes Node.js-Framework, body-parser ist eine Middleware, die den Anforderungstext analysiert, und mongoose wird mit der MongoDB-Datenbank verwendet Interaktives Objektmodell-Tool. 🎜🎜Schritt 3: Server und Routing erstellen🎜Erstellen Sie im Stammverzeichnis des Projekts die Datei server.js und fügen Sie den folgenden Code hinzu: 🎜rrreee🎜Dieser Code führt zuerst das erforderliche npm-Paket ein. Dann Erstellen Sie eine Express-Anwendung und stellen Sie den Server-Port auf 3000 ein. Danach verwenden wir die Methode mongoose.connect(), um eine Verbindung zur MongoDB-Datenbank herzustellen. Bitte stellen Sie sicher, dass der MongoDB-Dienst auf dem Standardport 27017 des lokalen Computers ausgeführt wird. Als nächstes richten wir hauptsächlich zu Testzwecken eine Root-Route ein. Schließlich verwenden wir die Methode app.listen(), um den Server zu starten und Port 3000 abzuhören. 🎜🎜Schritt 4: Modell und Routing definieren🎜Wir erstellen ein einfaches Datenbankmodell mit dem Namen product und schreiben die entsprechende CRUD-Route. Fügen Sie den folgenden Code in die Datei server.js ein: 🎜rrreee🎜In diesem Code stellen wir zunächst das Modell Product vor, bei dem es sich um ein Modell handelt, das auf mongoose basiert. Das einfache MongoDB-Modell von Schema . Anschließend haben wir Routen für die Abfrage aller Produkte, die Abfrage eines einzelnen Produkts, die Erstellung eines neuen Produkts, die Aktualisierung eines Produkts und die Löschung eines Produkts definiert. In jeder Route verwenden wir die entsprechende mongoose-Methode, um mit der MongoDB-Datenbank zu interagieren und basierend auf den zurückgegebenen Ergebnissen entsprechende Antworten zu senden. 🎜🎜Schritt 5: Definieren Sie das Modell🎜Erstellen Sie im Stammverzeichnis des Projekts ein Verzeichnis models und erstellen Sie darin die Datei product.js. Fügen Sie den folgenden Code in die Datei product.js ein: 🎜rrreee🎜Dieser Code definiert ein einfaches Produktmodell Product, das einen Namen name Eine Zeichenfolgeneigenschaft hat mit dem Namen <code>price und einer Zeichenfolgeneigenschaft mit dem Namen description. Übergeben Sie das Modell productSchema als Parameter an die Methode mongoose.model() und exportieren Sie das Produkt. 🎜🎜Schritt 6: Starten Sie den Server 🎜Im Stammverzeichnis des Projekts führen Sie den Server über den folgenden Befehl aus: 🎜rrreee🎜Wenn alles gut geht, sehen Sie die Meldung, dass die Datenbank erfolgreich verbunden wurde und der Server erfolgreich verbunden wurde auf der Kommandozeile gestartet. Jetzt können Sie in einem Browser oder Postman auf die verschiedenen Routen der API zugreifen, wie zum Beispiel: http://localhost:3000/api/products. 🎜🎜Zusammenfassung🎜Mit MongoDB und Node.js können wir ganz einfach eine einfache CRUD-API entwickeln. In diesem Artikel haben wir gelernt, wie man eine einfache CRUD-API mithilfe einer MongoDB-Datenbank, Node.js und dem Express.js-Framework erstellt, und haben spezifische Codebeispiele bereitgestellt. Mit einem tieferen Verständnis von MongoDB und Node.js können Sie Ihre API entsprechend Ihren tatsächlichen Anforderungen erweitern und anpassen. 🎜

Das obige ist der detaillierte Inhalt vonSo entwickeln Sie eine einfache CRUD-API mit MongoDB. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage