如何在MongoDB数据库中存储图像而不仅仅是文本?我可以在MongoDB数据库中创建一个映像数组吗?在视频上也能做到吗?
当前回答
var upload = multer({dest: "./uploads"});
var mongo = require('mongodb');
var Grid = require("gridfs-stream");
Grid.mongo = mongo;
router.post('/:id', upload.array('photos', 200), function(req, res, next){
gfs = Grid(db);
var ss = req.files;
for(var j=0; j<ss.length; j++){
var originalName = ss[j].originalname;
var filename = ss[j].filename;
var writestream = gfs.createWriteStream({
filename: originalName
});
fs.createReadStream("./uploads/" + filename).pipe(writestream);
}
});
你认为:
<form action="/" method="post" enctype="multipart/form-data">
<input type="file" name="photos">
使用这段代码,您可以在MongoDB中添加单个以及多个映像。
其他回答
如果您正在使用任何脚本语言在MongoDB中存储文件/图像,则可以使用bin数据类型。Bin数据是为存储小文件而开发的。
参考脚本语言驱动程序。对于PHP,请单击这里。
http://blog.mongodb.org/post/183689081/storing-large-objects-and-files-in-mongodb
在NPM上有一个叫做Mongoose -file的插件。它允许您为文件上传添加文件字段到Mongoose Schema。我从未用过它,但它可能有用。 如果图像非常小,你可以用Base64编码它们并将字符串保存到数据库中。
在没有GridFS的情况下,使用MongoDB在NodeJS中存储一些小文件(小于1MB)
安装以下库
var express = require(‘express’);
var fs = require(‘fs’);
var mongoose = require(‘mongoose’);
var Schema = mongoose.Schema;
var multer = require('multer');
连接你的mongo db:
mongoose.connect(‘url_here’);
定义数据库模式
var Item = new ItemSchema({
img: {
data: Buffer,
contentType: String
}
}
);
var Item = mongoose.model('Clothes',ItemSchema);
使用中间件Multer在服务器端上传照片。
app.use(multer({ dest: ‘./uploads/’,
rename: function (fieldname, filename) {
return filename;
},
}));
Post req到我们的数据库
app.post(‘/api/photo’,function(req,res){
var newItem = new Item();
newItem.img.data = fs.readFileSync(req.files.userPhoto.path)
newItem.img.contentType = ‘image/png’;
newItem.save();
});
你能在MongoDB中存储文件吗?
Yes.
应该在MongoDB中存储文件吗?
No.
MongoDB不是一个存储文件的好地方。如果您想存储文件,您应该使用Amazon S3或谷歌Could Storage这样的存储。
好的做法是将文件存储在存储器中,然后将上传的图像的URI保存在MongoDB中。
你可以试试这个:
String newFileName = "my-image";
File imageFile = new File("/users/victor/images/image.png");
GridFS gfsPhoto = new GridFS(db, "photo");
GridFSInputFile gfsFile = gfsPhoto.createFile(imageFile);
gfsFile.setFilename(newFileName);
gfsFile.save();
推荐文章
- 如何从命令行在windows中找到mysql数据目录
- 如何找到MySQL的根密码
- MongoDB:如何找到安装的MongoDB的确切版本
- 将表从一个数据库复制到另一个数据库的最简单方法?
- 如何使用mongoimport导入CSV文件?
- 什么是分片,为什么它很重要?
- 在mongodb中存储日期/时间的最佳方法
- 数据库触发器是必要的吗?
- 如何排序mongodb与pymongo
- 如何在mongodb上导入。bson文件格式
- 为什么我应该使用基于文档的数据库而不是关系数据库?
- 哪个更快/最好?SELECT *或SELECT columnn1, colum2, column3等
- 将值从同一表中的一列复制到另一列
- 什么是数据库池?
- 关于数据库,每个开发人员应该知道些什么?