一、前言
有一个文件(如pdf、word等)需要存储,并且要求能够进行下载等操作。这篇文章主要介绍利用mongodb来存储文件。
有如下思考:
文件存储到临时磁盘,大文件如何分段存储到mongodb?
无论文件多大,利用GridFsTemplate的store方法进行存储,mongodb会自动去分段存储这个文件,一个chunks存储的文件大小是255KB。这些chunks统一返回files_id,由这个就可以获取完整的文件。
分段存储到mongodb的文件,能否分段下载?如何完整下载文件?
利用GridFsTemplate、GridFSBucket去获取完整的文件。
二、Mongodb存储代码实现
properties文件配置
# MongoDB单机
spring.data.mongodb.uri=mongodb://root:root@localhost:27017/wwy_test
spring.data.mongodb.database=wwy_test
config文件注入getGridFSBucket
@Configuration
public class Mongoconfig {
@Value("${spring.data.mongodb.database}")
String db;
@Bean
public GridFSBucket getGridFSBucket(MongoClient mongoClient){
MongoDatabase mongoDatabase = mongoClient.getDatabase(db);
GridFSBucket bucket = GridFSBuckets.create(mongoDatabase);
return bucket;
版权声明:本文为xunmengyou1990原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。