Rumah > hujung hadapan web > tutorial js > Cara melaksanakan muat naik fail dalam Nodejs: Panduan langkah demi langkah

Cara melaksanakan muat naik fail dalam Nodejs: Panduan langkah demi langkah

Patricia Arquette
Lepaskan: 2025-01-03 01:36:39
asal
866 orang telah melayarinya

pengenalan

Hai, Dalam artikel ini kita akan melihat cara mengendalikan muat naik fail dalam pelayan nodejs dan menyimpannya dengan amalan terbaik. Saya akan menggunakan awan Apexx sebagai perkhidmatan storan fail kami.

Pasang pakej

npm i express nodemon cors multer @apexxcloud/sdk-node dotenv
Salin selepas log masuk

Setelah dipasang, kemas kini package.json anda untuk menambah skrip mula

"scripts":{
 "start": "nodemon index.js",
 // rest of the scripts
}
Salin selepas log masuk

Buat fail index.js dalam folder akar, kemudian buat folder bernama src. Dalam folder src, cipta folder untuk pengawal dan laluan masing-masing, Struktur folder anda sepatutnya kelihatan seperti ini.

project-root/
│
├── index.js              # Entry point of the application
├── package.json          # Project metadata and dependencies
├── package-lock.json     # Auto-generated dependency tree
├── node_modules/         # Installed dependencies
│
└── src/
    ├── controllers/      # Contains controller files
    │   └── file.controller.js
    │
    ├── routes/           # Contains route files
    │   └── file.route.js

Salin selepas log masuk

Sediakan awan Apexx

  1. Log masuk ke awan Apexx atau buat akaun baharu di sini

  2. Navigasi ke baldi.

  3. Klik pada "Buat baldi" dan berikan nama unik untuk baldi anda.

  4. Pilih kawasan yang diingini

  5. Semak dan buat baldi

  6. Navigasi ke kekunci Api

  7. Klik pada "Buat Kunci API" dan berikan nama untuk kunci anda

  8. Semak dan buat kunci

  9. Salin kunci rahsia anda dan simpan di tempat yang selamat.

  10. Kemudian salin kekunci akses anda juga.

Mari mula menulis beberapa kod

Mari mula menulis pengawal kami yang akan mengendalikan permintaan dalam file.controller.js.

// Setup our apexx cloud sdk
const ApexxCloud = require("@apexxcloud/sdk-node");
const storage = new ApexxCloud({
  accessKey: process.env.APEXXCLOUD_ACCESS_KEY,
  secretKey: process.env.APEXXCLOUD_SECRET_KEY,
  region: process.env.APEXXCLOUD_REGION,
  bucket: process.env.APEXXCLOUD_BUCKET,
});

// Upload file function
const uploadFile = async (req, res) => {
  try {
    if (!req.file) {
      return res.status(400).json({ error: "No file provided" });
    }
    const { originalname, filename, size, path, mimetype } = req.file;

    const { key, visibility } = req.query;

    const result = await storage.files.upload(req.file.buffer, {
      key: key || orginalname,
      visibility: visiblity || "public",
      contentType: mimetype,
    });

    res.status(200).json(result);
  } catch (error) {
    console.log(error);
    res.status(500).json({ error: `File upload failed: ${error.message}` });
  }
};
Salin selepas log masuk

Mula-mula kami mengimport @apexxcloud/sdk-node dan kami mencipta objek storan dengan menghantar bukti kelayakan. Kemudian kami mencipta fungsi yang dipanggil uploadFile, Dalam fungsi itu kami mendapat kunci dan keterlihatan daripada req.query dan butiran fail daripada req.file

Kemudian kami menggunakan fungsi muat naik dari apexx cloud sdk untuk memuat naiknya ke apexx cloud. Apabila memuat naik, anda boleh mengkonfigurasi keterlihatan fail, Ia boleh menjadi awam atau peribadi, Semua fail adalah awam secara lalai.

Sekarang mari sediakan laluan dalam file.route.js.

const express = require("express");
const router = express.Router();
const multer = require("multer");
const { uploadFile } = require("../controllers/file.controller")

// setup multer
const upload = multer({ storage: multer.memoryStorage() });

// setup the route
router.post("/upload", upload.single("file"), uploadFile);

// export the router
module.exports = router
Salin selepas log masuk

Kemudian mari sediakan fail index.js.

const express = require("express");
const mongoose = require("mongoose");
const dotenv = require("dotenv");
const cors = require("cors");

// load env variables
dotenv.config();

// import file route
const fileRoute = require("./src/routes/file.route");

// setup express
const app = express();

app.use(express.urlencoded({ extended: true, limit: "100mb" }));
app.use(express.json({ limit: "100mb" }));
app.use(cors());

// setup the file route
app.use(fileRoutes);

const port = 8000
app.listen(port, () => {
  console.log(`Server running at port:${port}`);
});

Salin selepas log masuk

Buka terminal anda dan jalankan:

npm bermula, Jika semuanya berjalan lancar, ia harus log "Pelayan berjalan di port:8000".

Menguji API

Kami akan menguji API menggunakan posmen.

How to implement File uploads in Nodejs: A step by step guide

Pilih Badan, semak data borang, tambahkan kekunci yang dipanggil fail dan tetapkan jenis kepada fail. Muat naik fail anda kemudian klik hantar.

Anda sepatutnya mendapat respons seperti di bawah:

{
    "data": {
        "message": "File uploaded successfully",
        "key": "file.png",
        "location": "https://cdn.apexxcloud.com/f/ojGnBqCLkTnI/file",
        "bucket": "your-bucket-name",
        "region": "WNAM",
        "visibility": "private",
        "size": 14513,
        "content_type": "image/png"
    }
}
Salin selepas log masuk

Menunjukkan bahawa fail telah dimuat naik. Pergi ke papan pemuka Apexx Cloud anda, Kemudian pergi ke baldi anda, anda akan nampak fail yang anda muat naik di sana.

Dan itu sahaja, anda telah berjaya melaksanakan muat naik fail dalam nodejs dan bahagian yang terbaik ialah Apexx Cloud menyediakan anda dengan transformasi serta-merta dan CDN yang sangat pantas secara percuma. Untuk mengetahui lebih lanjut pergi ke sini, untuk dokumentasi pergi ke sini.

Kesimpulan

Artikel ini telah berjaya mengajar anda cara mengendalikan muat naik fail dalam aplikasi nodejs menggunakan Apexx Cloud dan Multer.

Dalam artikel seterusnya saya akan menunjukkan cara menggunakan AWS S3 untuk muat naik fail, sehingga kemudian Menandatangani Mati - FII Anda

Jangan risau tentang muat naik fail: Daftar untuk Apexx Cloud Hari Ini, Ianya Percuma

Atas ialah kandungan terperinci Cara melaksanakan muat naik fail dalam Nodejs: Panduan langkah demi langkah. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:dev.to
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan