


Comment utiliser Express pour gérer le téléchargement de fichiers dans un projet de nœud
怎么处理文件上传?下面本篇文章给大家介绍一下node项目中如何使用express来处理文件的上传,希望对大家有所帮助!
上传单个文件
我们可以使用 express 官方出品的第三方中间件 multer 来处理,先是安装:
npm i multer
然后我先放段比较完整的代码,之后解释:
const express = require('express') const multer = require('multer') const app = express() const upload = multer({ dest: './uploads' }) app.post('/upload', upload.single('file'), (req, res) => { console.log(req.file) res.end('上传成功') }) app.listen(4396, () => { console.log('服务器开启') })
引入后的 multer
为一个函数,执行它得到 upload
对象,执行时可以传入配置,比如设置 dest
(destination 的缩写) 为 './uploads'
,用于指定上传后的文件的存放位置: 【相关教程推荐:nodejs视频教程、编程教学】
const upload = multer({ dest: './uploads' })
由于对上传文件的处理并不是普遍需要的,所以对 upload
的使用是直接在匹配上传路径(我们定义为 '/upload'
)和方法(一般为 POST)的 app.post('/upload', )
内,处理的是单个文件上传,所以使用 upload.single()
方法,传入的 'file'
(自定义,也可以为其它名字) 为上传文件时的 key:
其执行会返回一个中间件函数,将得到的文件的数据赋值到 req.file
,而文本字段的信息则会放在 req.body
中,并调用 next()
,这样我们就可以接着注册一个中间件,打印查看文件信息,并向客户端返回请求结果 :
app.post('/upload', upload.single('file'), (req, res) => { console.log(req.body) console.log(req.file) res.end('上传成功') })
发起上传请求后,打印得到的 req.body
如下:
[Object: null prototype] { name: 'jay' }
注意,如果请求的 body 使用 form-data
格式携带的数据里没有文件,而仅仅是一些文本字段,则 upload.single('file')
可以换成 upload.any()
。
打印得到的 req.file
如下:
{ fieldname: 'file', originalname: 'Comment utiliser Express pour gérer le téléchargement de fichiers dans un projet de nœud', encoding: '7bit', mimetype: 'image/png', destination: './uploads', filename: '4c5781db70269d90cc57249e95a28894', path: 'uploads\\4c5781db70269d90cc57249e95a28894', size: 904454 }
并且文件会存储在 uploads 目录下:
可以看到,文件名为哈希值,且没有后缀,在 vscode 里无法直接查看图片:
但图片文件是可用的,使用 ps 是可以直接打开查看的。那如果想让文件存储时的文件名是添加后缀的,要怎么办呢?解决方案是在执行 const upload = multer()
时,传入的配置对象不再设置 dest
的值而改为设置 storage
:
const storage = multer.diskStorage({ destination(req, file, cb) { cb(null, './uploads') }, filename(req, file, cb) { cb(null, Date.now() + '-' + file.originalname) } }) const upload = multer({ storage })
storage
对象由 multer.diskStorage()
生成,其内部传入对象,该对象有两个方法属性,它们都有 3 个参数,请求对象 req
,文件信息 file
,和一个回调函数 cb
:
destination
就是配置文件存储路径的,其作用等同于之前直接往multer()
传入的{ dest: './uploads' }
,存储路径通过 cb 的第二个参数传入,cb 的第一个参数可以传 Error 对象或直接传null
;filename
就可以用来自定义文件名,因为file.originalname
也就是上传的文件的原来的文件名,其是带有后缀的,所以我们在它前面加个时间戳来作为存储时的文件名。
现在再次发送上传文件请求,存储到 uploads 目录下的文件就有带后缀名了,可以直接在 vscode 打开查看:
上传多个文件
如果请求一次性上传多个文件,则只需要将 upload.single('file')
替换为 upload.array('files', 3)
即可,传入参数意为上传时文件的 key 为 files(自定义的,也可以是其它名字),并且限制最多上传 3 张图片,得到的文件信息可以在下一个中间件函数的 req.files
获取:
app.post('/upload', upload.array('files', 3), (req, res) => { console.log(req.files) res.end('上传成功') })
当我们一次上传多个文件时:
打印 req.files
得到的就是个数组了:
[ { fieldname: 'files', originalname: 'Comment utiliser Express pour gérer le téléchargement de fichiers dans un projet de nœud', encoding: '7bit', mimetype: 'image/png', destination: './uploads', filename: '1676958850980-Comment utiliser Express pour gérer le téléchargement de fichiers dans un projet de nœud', path: 'uploads\\1676958850980-Comment utiliser Express pour gérer le téléchargement de fichiers dans un projet de nœud', size: 904454 }, { fieldname: 'files', originalname: 'qrcode.png', encoding: '7bit', mimetype: 'image/png', destination: './uploads', filename: '1676958850986-qrcode.png', path: 'uploads\\1676958850986-qrcode.png', size: 1076 } ]
将文件部署为静态资源
可以使用内置的 express.static('./uploads')
中间件函数将存储上传文件的 uploads 目录设置为静态资源。然后传给 app.use()
:
app.use(express.static('./uploads'))
这样我们就可以直接通过浏览器查看上传得到的文件了,比如 uploads 有张图片如下:
只需要在浏览器输入 localhost:4396/1677031777791-Comment utiliser Express pour gérer le téléchargement de fichiers dans un projet de nœud 即可查看。
更多node相关知识,请访问:nodejs 教程!
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Node.js peut être utilisé comme framework backend car il offre des fonctionnalités telles que des performances élevées, l'évolutivité, la prise en charge multiplateforme, un écosystème riche et une facilité de développement.

Pour vous connecter à une base de données MySQL, vous devez suivre ces étapes : Installez le pilote mysql2. Utilisez mysql2.createConnection() pour créer un objet de connexion contenant l'adresse de l'hôte, le port, le nom d'utilisateur, le mot de passe et le nom de la base de données. Utilisez connection.query() pour effectuer des requêtes. Enfin, utilisez connection.end() pour mettre fin à la connexion.

Comment implémenter le téléchargement de fichiers à l'aide de gRPC ? Créez des définitions de service de support, y compris des messages de demande et de réponse. Sur le client, le fichier à télécharger est ouvert et divisé en morceaux, puis diffusé sur le serveur via un flux gRPC. Côté serveur, des fragments de fichiers sont reçus et stockés dans un fichier. Le serveur envoie une réponse une fois le téléchargement du fichier terminé pour indiquer si le téléchargement a réussi.

Les variables globales suivantes existent dans Node.js : Objet global : global Module principal : processus, console, nécessiter Variables d'environnement d'exécution : __dirname, __filename, __line, __column Constantes : undefined, null, NaN, Infinity, -Infinity

Il existe deux fichiers liés à npm dans le répertoire d'installation de Node.js : npm et npm.cmd. Les différences sont les suivantes : différentes extensions : npm est un fichier exécutable et npm.cmd est un raccourci de fenêtre de commande. Utilisateurs Windows : npm.cmd peut être utilisé à partir de l'invite de commande, npm ne peut être exécuté qu'à partir de la ligne de commande. Compatibilité : npm.cmd est spécifique aux systèmes Windows, npm est disponible multiplateforme. Recommandations d'utilisation : les utilisateurs Windows utilisent npm.cmd, les autres systèmes d'exploitation utilisent npm.

Les principales différences entre Node.js et Java résident dans la conception et les fonctionnalités : Piloté par les événements ou piloté par les threads : Node.js est piloté par les événements et Java est piloté par les threads. Monothread ou multithread : Node.js utilise une boucle d'événements monothread et Java utilise une architecture multithread. Environnement d'exécution : Node.js s'exécute sur le moteur JavaScript V8, tandis que Java s'exécute sur la JVM. Syntaxe : Node.js utilise la syntaxe JavaScript, tandis que Java utilise la syntaxe Java. Objectif : Node.js convient aux tâches gourmandes en E/S, tandis que Java convient aux applications de grande entreprise.

Oui, Node.js est un langage de développement backend. Il est utilisé pour le développement back-end, notamment la gestion de la logique métier côté serveur, la gestion des connexions à la base de données et la fourniture d'API.

Explication détaillée et guide d'installation pour les nœuds de pignon Cet article introduira l'écosystème de pignon en détail - nœuds PI, un rôle clé dans l'écosystème de pignon et fournir des étapes complètes pour l'installation et la configuration. Après le lancement du réseau de test de la blockchain pèse, les nœuds PI sont devenus une partie importante de nombreux pionniers participant activement aux tests, se préparant à la prochaine version du réseau principal. Si vous ne connaissez pas encore Pinetwork, veuillez vous référer à ce qu'est Picoin? Quel est le prix de l'inscription? PI Utilisation, exploitation minière et sécurité. Qu'est-ce que Pinetwork? Le projet Pinetwork a commencé en 2019 et possède sa pièce exclusive de crypto-monnaie PI. Le projet vise à en créer un que tout le monde peut participer
