Mongo 单个文档上限时16M,如果超过16M则需要采用GridFs方式将文件拆分
GridFS使用两个Collection存储文件:
fs.file: 用于存储文件的元数据 (metadata)
fs.chunk:存储文件内容的二进制数据(payload)
读文件时,先根据查询条件在file中找到对应文档,在根据_id映射到chunk collection中查询所有file_id=_id 的文档,最后根据n字段顺序读取chunk的data字段还原文件
code:
package com.example.mongo.binary.api.controller; import java.io.ByteArrayInputStream; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.nio.file.Files; import java.nio.file.Paths; import java.util.Date; import java.util.zip.ZipEntry; import java.util.zip.ZipOutputStream; import javax.sql.rowset.CachedRowSet; import com.example.mongo.binary.api.config.MongoConfig; import com.example.mongo.binary.api.entity.PayloadEntity; import com.mongodb.MongoClient; import org.apache.commons.io.FileUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.mongodb.core.MongoTemplate; import org.springframework.data.mongodb.core.query.Criteria; import org.springframework.data.mongodb.core.query.Query; import org.springframework.data.mongodb.gridfs.GridFsOperations; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RestController; import com.mongodb.BasicDBObject; import com.mongodb.DBObject; import com.mongodb.gridfs.GridFSDBFile; /** * Realiza la interacción con la BD las dos colecciones de GridFs. * @author Ever */ @RestController public class BinaryDataController { //Interfaz de operaciones para Grid provista por SpringBoot, inyección Dependencia. @Autowired private GridFsOperations gridFsOperations; @Autowired private MongoTemplate mongoTemplate; @Autowired private MongoConfig mongoConfig; /** * Guarda un pdf en GridFS. * @param , el nombre del archivo sin la extensión esa se agrega en el método * @return, mensaje con el fileId del archivo. * @throws FileNotFoundException, puede que no encuentre el nombre del archivo en el directorio preestablecido. */ @GetMapping("/savePdf") public String savePdf() throws FileNotFoundException { String file="C:\\testcase\\test\\22222222.txt"; String extension=".pdf"; //Define Metadata DBObject metadata=new BasicDBObject(); metadata.put("type", "data"); //Store File //el nombre es el tercer Parametro int fileId=gridFsOperations.store(new FileInputStream("C:\\testcase\\test\\22222222.txt"), file,"type/txt",metadata).getMachineIdentifier(); //System.out.println("El id de almacenado fué: "+fileId); return "File Stored Sucessfully: "+file+"with FileId : "+fileId; } @GetMapping("/savetxt/grid") public String savetxt() throws FileNotFoundException { String file="C:\\testcase\\test\\1111.txt"; //Define Metadata DBObject metadata=new BasicDBObject(); metadata.put("type", "data"); //Store File //el nombre es el tercer Parametro int fileId=gridFsOperations.store(new FileInputStream(file), file,"type/txt",metadata).getMachineIdentifier(); //System.out.println("El id de almacenado fué: "+fileId); return "File Stored Sucessfully: "+file+"with FileId : "+fileId; } @GetMapping("/savetxt/mongotemplate") public void savetxtmongotemplate() throws IOException { String file="C:\\testcase\\test\\1111.txt"; PayloadEntity payloadEntity=new PayloadEntity(); payloadEntity.setPayload(Files.readAllBytes(Paths.get(file))); mongoTemplate.save(payloadEntity,mongoConfig.getCollectionName()); }