Mongodb與spring集成(4)------讀寫mongo GridFs中的文件

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;
  }



 

發佈了68 篇原創文章 · 獲贊 158 · 訪問量 75萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章