上传图片错误(NodeJs/Formidable)

发布于 2025-01-09 06:37:40 字数 1501 浏览 1 评论 0原文

我使用 [email protected] 上传该内容图像,如下教程你。我得到了下面的。 如何调试这个错误?

错误:“path”参数必须是字符串类型或者 Buffer 或 URL 的实例。收到未定义

Controller.js

const formidable = require("formidable");
const _ = require("lodash");
const fs = require("fs");
const Project = require("../models/projectModel");

exports.create = (req, res) => {
let form = new formidable.IncomingForm();
form.keepExtensions = true;

form.parse(req, (err, fields, files) => {
if (err) {
  return res.status(400).json({
    error: "Image could not be uploaded",
  });
}
let project = new Project(fields);

if (files.image) {
  project.image.data = fs.readFileSync(files.image.path);

  project.image.contentType = files.image.type;
}

project.save((err, result) => {
  if (err) {
    return res.status(400).json({
      error: errorHandler(error),
    });
  }
  res.json(result);
});
});
};

projectModel.js

const mongoose = require("mongoose");
const { ObjectId } = mongoose.Schema;

const projectSchema = new mongoose.Schema(
 {
title: {
  type: String,
  trim: true,
  require: true,
 },
 category: {
  type: ObjectId,
  ref: "Category",
  required: true,
 },
 image: {
  data: Buffer,
  contentType: String,
 },
},
{
timestamps: true,
}
);

module.exports = mongoose.model("Project", projectSchema);

I was using [email protected] to upload form that contents image, following a tutorial thou. I got the below.
How to debug this error?

Error: The "path" argument must be of type string or an instance of Buffer or URL. Received undefined

Controller.js

const formidable = require("formidable");
const _ = require("lodash");
const fs = require("fs");
const Project = require("../models/projectModel");

exports.create = (req, res) => {
let form = new formidable.IncomingForm();
form.keepExtensions = true;

form.parse(req, (err, fields, files) => {
if (err) {
  return res.status(400).json({
    error: "Image could not be uploaded",
  });
}
let project = new Project(fields);

if (files.image) {
  project.image.data = fs.readFileSync(files.image.path);

  project.image.contentType = files.image.type;
}

project.save((err, result) => {
  if (err) {
    return res.status(400).json({
      error: errorHandler(error),
    });
  }
  res.json(result);
});
});
};

projectModel.js

const mongoose = require("mongoose");
const { ObjectId } = mongoose.Schema;

const projectSchema = new mongoose.Schema(
 {
title: {
  type: String,
  trim: true,
  require: true,
 },
 category: {
  type: ObjectId,
  ref: "Category",
  required: true,
 },
 image: {
  data: Buffer,
  contentType: String,
 },
},
{
timestamps: true,
}
);

module.exports = mongoose.model("Project", projectSchema);

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

究竟谁懂我的在乎 2025-01-16 06:37:40

在Controller.js中,我将files.image.path更改为files.image.filepath,并将files.image.type更改为files.image.mimetype

Controller.js

const formidable = require("formidable");
const _ = require("lodash");
const fs = require("fs");
const Project = require("../models/projectModel");

exports.create = (req, res) => {
let form = new formidable.IncomingForm();
form.keepExtensions = true;

form.parse(req, (err, fields, files) => {
if (err) {
return res.status(400).json({
error: "Image could not be uploaded",
 });
}
let project = new Project(fields);

if (files.image) {
project.image.data = fs.readFileSync(files.image.filepath);

project.image.contentType = files.image.mimetype;
}

project.save((err, result) => {
if (err) {
return res.status(400).json({
  error: errorHandler(error),
});
}
res.json(result);
 });
});
};

In Controller.js I changed files.image.path to files.image.filepath and also changed files.image.type to files.image.mimetype

Controller.js

const formidable = require("formidable");
const _ = require("lodash");
const fs = require("fs");
const Project = require("../models/projectModel");

exports.create = (req, res) => {
let form = new formidable.IncomingForm();
form.keepExtensions = true;

form.parse(req, (err, fields, files) => {
if (err) {
return res.status(400).json({
error: "Image could not be uploaded",
 });
}
let project = new Project(fields);

if (files.image) {
project.image.data = fs.readFileSync(files.image.filepath);

project.image.contentType = files.image.mimetype;
}

project.save((err, result) => {
if (err) {
return res.status(400).json({
  error: errorHandler(error),
});
}
res.json(result);
 });
});
};
傲鸠 2025-01-16 06:37:40

// photo 是 html 输入中给出的名称

<form action="/add" method="post" enctype="multipart/form-data">
<div class="form">
<div class="center">
<div class="form-input">
<label for="file-ip-1">Upload Image</label>
<input type="file" name="**photo**" id="file-ip-1" accept="image/*" onchange="showPreview(event);">
</div>
</div>
</form>

const express = require("express");
const Router = express.Router();
const User = require("../models/users");
const path = require("path");
const fs = require("fs");
const bodyParser = require("body-parser");

// var jsonParser = bodyParser.json();
var urlencodedParser = bodyParser.urlencoded({ extended: false });

// for image
const formidable = require("formidable");

Router.get("/", (err, res) => {
    res.render("index")
})

// create / insert

Router.post("/add", (req, res) => {

// for image
const form = new formidable.IncomingForm();

form.parse(req, (err, fields, file) => {
if (err) {
return res.status(400).json({ error: err })
}

let oldPath = file.photo[0].filepath;
let newPath = path.join("E:", "CRUD-MONGO-11-07-2023", "public", 'uploads') + '/' + file.photo[0].  originalFilename;

photo = file.photo[0].originalFilename;
console.log(photo);

let rawData = fs.readFileSync(oldPath)
fs.writeFile(newPath, rawData, function (err) {
if (err) {
console.log(err);
}
})

})
})

// photo is the name which given inside the html input

<form action="/add" method="post" enctype="multipart/form-data">
<div class="form">
<div class="center">
<div class="form-input">
<label for="file-ip-1">Upload Image</label>
<input type="file" name="**photo**" id="file-ip-1" accept="image/*" onchange="showPreview(event);">
</div>
</div>
</form>

const express = require("express");
const Router = express.Router();
const User = require("../models/users");
const path = require("path");
const fs = require("fs");
const bodyParser = require("body-parser");

// var jsonParser = bodyParser.json();
var urlencodedParser = bodyParser.urlencoded({ extended: false });

// for image
const formidable = require("formidable");

Router.get("/", (err, res) => {
    res.render("index")
})

// create / insert

Router.post("/add", (req, res) => {

// for image
const form = new formidable.IncomingForm();

form.parse(req, (err, fields, file) => {
if (err) {
return res.status(400).json({ error: err })
}

let oldPath = file.photo[0].filepath;
let newPath = path.join("E:", "CRUD-MONGO-11-07-2023", "public", 'uploads') + '/' + file.photo[0].  originalFilename;

photo = file.photo[0].originalFilename;
console.log(photo);

let rawData = fs.readFileSync(oldPath)
fs.writeFile(newPath, rawData, function (err) {
if (err) {
console.log(err);
}
})

})
})
仅此而已 2025-01-16 06:37:40

解决方案是循环遍历文件并检索详细信息

const http = require('http');
const formidable = require('formidable');
const fs = require('fs');
const path = require('path');

const server = http.createServer((req, res) => {
  if (req.url === '/upload' && req.method.toLowerCase() === 'post') {
    const form = new formidable.IncomingForm();

    // Specify the directory where uploaded files will be stored
    form.uploadDir = path.join(__dirname, 'uploads');

    form.parse(req, (err, fields, files) => {
      if (err) {
        console.error(err);
        return;
      }
      var originalFilename,oldPath;
      console.log(files)
      const uploadedFiles = files.file;
      
      uploadedFiles.forEach((uploadedFile) => {
      originalFilename = uploadedFile.originalFilename;
      oldPath = uploadedFile.filepath;
        console.log(originalFilename);    
      });
      const newPath = path.join(form.uploadDir, originalFilename);

      fs.rename(oldPath, newPath, (err) => {
        if (err) {
          console.error(err);
          return;
        }

        res.writeHead(200, { 'Content-Type': 'text/plain' });
        res.end('File uploaded successfully');
      });
    });
  } else {
    res.writeHead(200, { 'Content-Type': 'text/html' });
    res.end(`
      <form action="/upload" method="post" enctype="multipart/form-data">
        <input type="file" name="file">
        <input type="submit" value="Upload File">
      </form>
    `);
  }
});

const port = 3000;
server.listen(port, () => {
  console.log(`Server is running on http://localhost:${port}`);
});

Solution is to loop through the files and retrieve the details

const http = require('http');
const formidable = require('formidable');
const fs = require('fs');
const path = require('path');

const server = http.createServer((req, res) => {
  if (req.url === '/upload' && req.method.toLowerCase() === 'post') {
    const form = new formidable.IncomingForm();

    // Specify the directory where uploaded files will be stored
    form.uploadDir = path.join(__dirname, 'uploads');

    form.parse(req, (err, fields, files) => {
      if (err) {
        console.error(err);
        return;
      }
      var originalFilename,oldPath;
      console.log(files)
      const uploadedFiles = files.file;
      
      uploadedFiles.forEach((uploadedFile) => {
      originalFilename = uploadedFile.originalFilename;
      oldPath = uploadedFile.filepath;
        console.log(originalFilename);    
      });
      const newPath = path.join(form.uploadDir, originalFilename);

      fs.rename(oldPath, newPath, (err) => {
        if (err) {
          console.error(err);
          return;
        }

        res.writeHead(200, { 'Content-Type': 'text/plain' });
        res.end('File uploaded successfully');
      });
    });
  } else {
    res.writeHead(200, { 'Content-Type': 'text/html' });
    res.end(`
      <form action="/upload" method="post" enctype="multipart/form-data">
        <input type="file" name="file">
        <input type="submit" value="Upload File">
      </form>
    `);
  }
});

const port = 3000;
server.listen(port, () => {
  console.log(`Server is running on http://localhost:${port}`);
});
巷子口的你 2025-01-16 06:37:40

使用 multer npm 效果很好

const express = require('express')
const multer  = require('multer')
const upload = multer({ dest: 'uploads/' })

const app = express()


app.post('/profile', upload.single('avatar'), function (req, res, next) {
  // req.file is the `avatar` file
  // req.body will hold the text fields, if there were any
 console.log(req.file, req.body)
})



use multer npm its works fine

const express = require('express')
const multer  = require('multer')
const upload = multer({ dest: 'uploads/' })

const app = express()


app.post('/profile', upload.single('avatar'), function (req, res, next) {
  // req.file is the `avatar` file
  // req.body will hold the text fields, if there were any
 console.log(req.file, req.body)
})



~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文