- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试将上传到nodejs服务器的文件存储到mysql数据库中。该文件使用 Multer 上传和处理。中间件,从而将所有文件信息存储在 req.files
中。我相信,如果我错了,请纠正我,这些数据/参数必须以某种方式转换为 blob 格式,但我不知道如何有效地这样做。如何才能将其上传到 MySQL 数据库?
我正在使用最新版本的 XAMPP 和 MySQL InnoDB 表。 Multer 生成的文件参数/数据如代码片段所示。我尝试将整个文件(即 req.files[0]
)转换为 blob,但存储在 MySQL 数据库中的 blob 大小相同,尽管使用不同的文件。
[ { fieldname: 'files',
originalname: 'Event Information 2018-1_2084.pdf',
encoding: '7bit',
mimetype: 'application/pdf',
destination:
'/home/millana/Desktop/Brandink/Code/server/middleware/../designs/',
filename: 'Event Information 2018-1_2084_1559843587360.pdf',
path:
'/home/millana/Desktop/Brandink/Code/server/designs/Event Information 2018-1_2084_1559843587360.pdf',
size: 1125992 } ]
下面显示了调用的restAPI,用于在现有表Designs
和数据库上执行查询。
router.post('/order', upload.array('files'), (req, res) => {
console.log(req.files[0].buffer);
const order_id = 1;
const position = 'front';
const sql = `INSERT INTO Designs VALUES ('${order_id}', '${position}', '${req.files[0].filename}', '${req.files[0].mimetype}', '${req.files[0].buffer}')`;
db.query(sql, (err, result) => {
if(err) res.status(400).send(err);
res.status(200).send(result);
});
});
中间件功能包括:
const storage = multer.diskStorage({
destination: function(req, file, cb) {
cb(null, __dirname + '/../designs/');
},
filename: function (req, file, cb) {
let format = '';
if ( file.mimetype === 'image/jpeg' ) format = '.jpg';
else if ( file.mimetype === 'image/png' ) format = '.png';
else if ( file.mimetype === 'application/pdf' ) format = '.pdf';
let fileName = _.split(file.originalname, '.')[0] + '_' + Date.now() + format;
cb(null, fileName);
}
});
const upload = multer({
storage: storage,
limits: {
fileSize: MAX_SIZE
},
});
我预计每个文件的 blob 大小会随着文件大小的变化而变化。然而,所有上传的文件的大小都是 9 字节,而缓冲区是相同的,这表明正在存储相同的对象/文件。如何相应地存储每个不同的文件?
最佳答案
使用文件过滤器怎么样?您可以管理文件的质量或大小等。 https://github.com/expressjs/multer
正如您在链接或您的知识中看到的那样,multer 有一些选项,例如文件过滤器或限制。fileFilter,与您的功能类似,用于选择文件类型。限制,
文件大小:{ 5*1024*1024}
而且我听说存储图像等文件就是将二进制文件转换为缓冲区中的二进制文件。
如果你console.log(img file),你可以看到如下输出二进制{ _bsontype: '二进制', 子类型:0, 位置:260547, 缓冲区: } }
然后将数组Buffer更改为base64,字符串。结果是,
数据:图像/jpeg;base64,v9emlk3SGF45fg...
它与“文件名或originalName”不同,
这样它就可以另存为另一个。
关于mysql - 如何在 MySQL 中将 multer 文件作为 blob 上传?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56483286/
我有这个用于上传文件的中间件。 @Injectable() export class FilesMiddleware implements NestMiddleware { private sto
我在使用 multer 和 multer-s3 npm 以及 node.js 和express 将图像上传到 S3 时遇到问题。 我已阅读 multer 和 multer-s3 的文档并按照教程进行操
任何人都知道为什么“重命名”函数(以及所有其他 multer 回调)不起作用? var express = require('express'); var multer = require('mul
我有这个nodejs应用程序。很简单。 var express = require('express'); var multer = require('multer'); var upload = m
routes.js module.exports=function(app, upload){ var postingsController=require('../controlle
我正在使用 FormData 上传文件并使用 Multer 在服务器端接收该文件。一切都按预期工作,除了因为我在前端使用 FileSystem API ( https://developer.mozi
我正在使用multer要将图像上传到快速服务器,默认情况下 multer 会创建自动生成/随机文件名(这通常很好),但在我的特殊情况下,我需要文件名与原始文件名相同,我尝试了以下方法: const u
我对 multer/node/express/mongoose/... 相当陌生,我目前正在尝试从具有相同名称的不同输入上传多个文件(我使用reactjs 生成输入)。 这是我的 React 前端:
我正在尝试使用 multer 将文件从客户端的 html 表单上传到服务器端,multer 模块在服务器端处理文件。 这里的事情是一切正常,因为我从服务器收到 200 ok 响应,但文件应该上传到我的
我在 Internet 上到处查看,但没有发现任何看起来像我的问题。我是 Node.JS 的新手,我想使用 Multer 上传两张不同的图片,但格式相同。这是我的表格: Add a prof
我这辈子都无法使 multer 的文件上传正常工作。我已经阅读了数十个教程,遵循了 YT 指南,并搜索了数十个 StackOverflow 问题,但无法通过 Postman 解决问题。 这是路由的页面
我想在单个 post 请求中保存一张图像,这将是用户对 MongoDB 的头像,以及一些用户的信息,使用来自 npm 的名为 multer 的包。不幸的是,只有我在控制台中看到的是错误:TypeErr
我正在使用 Multer 来管理图像上传,当在本地计算机上运行我的应用程序时,一切都运行良好。但现在我尝试部署到 Heroku,我在应用程序日志中收到此错误: Unhandled rejection
我在使用 Multer 保存多个图像时遇到问题 路线如下: router.post('/imagesSection', upload.array('up
我使用 multer . 问题 1 当我将以下代码段放入 app.js app.use(multer({ dest: './uploads' } ).single('file'
我有一个这样的对象数组: data: [ {"image": File, "certificate": File}, {"image": File, "certificate": Fi
我知道我可以通过 multer 通过存储对象更改文件名,如下所示: const storage = multer.diskStorage({ destination: (req, file,
我正在使用 Multer保存我通过表单上传的文件,但我不知道为什么我的代码将它保存为一个奇怪的名称并且没有扩展名,我刚刚使用了文档中的代码。 server.js: const multer = re
我正在尝试将图像(jpg/jpeg/png)从浏览器上传到 NodeJS。我已经阅读了几个教程和论坛上的许多帖子,但似乎很少有人遇到这个特定问题。 我已确保将提供给 multer 的名称 ( uplo
我创建了一个 node.js 服务器,并使用 multer 模块上传一些文件。 我的问题是:我该如何处理错误?就像客户端关闭直到上传完成?抱歉英语不好,我是意大利人。 这是我实际不起作用的代码: va
我是一名优秀的程序员,十分优秀!