1.下载包
npm i formidable
2.传入形式
const formidable = require('formidable'); const form = formidable(options); // or const {
formidable } = require('formidable'); const form = formidable(options); // or const {
IncomingForm } = require('formidable'); const form = new IncomingForm(options); // or const {
Formidable } = require('formidable'); const form = new Formidable(options);
3.英雄案例后台-文件上传
// 引入实现文件上传的模块 const {
IncomingForm } = require('formidable') const path = require('path') module.exports = {
// 实现文件上传 uploadFile: function (req, res) {
// 1.创建文件上传对象 let form = new IncomingForm() // 2.添加必要的配置 // 2.1 设置编码,formidable也可 接收普通键值对,这个时候就有需要设置编码,如果只是上传文件,则不用设置 // form.encoding = 'utf-8' // // 2.2 设置上传文件的存放路径,一定给一个全路径,否则报错 form.uploadDir = __dirname + '/public/images' // // 2.3 设置是否保留文件的扩展名,默认不保留 form.keepExtensions = true // 3.调用上传方法,实现文件上传 // form.parse(请求报文,回调函数) // err:文件上传失败时的错误信息 // fields:接收到普通键值对--对象 // files:文件的相关信息,特别是上传成功后在服务器端的信息 form.parse(req, (err, fields, files) => {
if (err) {
console.log(err) res.json({
code: 204, msg: '文件上传失败' }) } else {
res.json({
code: 200, msg: '文件上传成功', img: path.basename(files.img.path) }) } }) }, }
发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/214029.html原文链接:https://javaforall.net
