mongodb裏面自帶有一個分佈式文件系統gridFs,它是以塊的方式來存儲文件的,一般的存儲都夠用了,國內一個使用例子是視覺中國使用它來進行上億數據級的圖片存儲,可以看出這套文件系統還是挺強大的。下面介紹下如何用spring-data-mongodb來對其進行操作,其實spring-data-mongodb並沒有對gridfs進行再次封裝,我們只能自己根據需要簡單封裝下接口,mongodb java api中操作gridfs也是很簡單的,1.得到DB對象,2.new 一個GridFSInputFile對象,這個對象相當於一個文件記錄,包含文件和與這個文件相關的信息。3.調用save方法保存。讀取文件時可以根據文件名和id來對文件進行查詢,查詢出來一個GridFSDBFile 對象,再把這個對象輸出到流或文件中。
先注入MongoDbFactory
@Autowired
private MongoDbFactory mongoDbFactory;
獲得DB對象
DB db = mongoDbFactory.getDb();
保存文件(其中FS_NAME相當於gridfs文件系統的表名,可以有多個)
public boolean saveFile(File file, String fileName, String contentType,
DBObject metaData) {
GridFSInputFile gfsInput;
try {
gfsInput = new GridFS(db, FS_NAME).createFile(file);
gfsInput.setFilename(fileName);
gfsInput.setContentType(contentType);
gfsInput.setMetaData(metaData);
gfsInput.save();
} catch (IOException e) {
log.error(e, e);
return false;
}
return true;
}
通過文件名讀取文件
public GridFSDBFile findFileByName(String fileName){
GridFSDBFile gfsFile ;
try {
gfsFile = new GridFS(db, FS_NAME).findOne(fileName);
} catch (Exception e) {
log.error(e, e);
return null;
}
return gfsFile;
}
通過id讀取文件
public GridFSDBFile findFileById(String id){
GridFSDBFile gfsFile ;
try {
gfsFile = new GridFS(db, FS_NAME).find(new ObjectId(id));
} catch (Exception e) {
log.error(e, e);
return null;
}
return gfsFile;
}
輸出文件到OutputStream
private boolean writeToOutputStream(OutputStream out, GridFSDBFile gfsFile) {
try {
gfsFile.writeTo(out);
} catch (IOException e) {
log.error(e, e);
return false;
}
return true;
}