Spring Data MongoDB: Enregistrer un fichier binaire, exemple GridFS

Spring Data MongoDB: Enregistrer le fichier binaire, exemple GridFS

binary-data-flow

Dans MongoDB, vous pouvez utiliser GridFS pour stocker des fichiers binaires. Dans ce didacticiel, nous vous montrons comment utiliser lesGridFsTemplate de Spring Data pour stocker / lire une image dans / depuis MongoDB.

1. GridFS - exemple d'enregistrement (configuration de printemps dans l'annotation)

Gat un fichier image et enregistrez-le dans MongoDB.

SpringMongoConfig.java

package com.example.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.mongodb.config.AbstractMongoConfiguration;
import org.springframework.data.mongodb.gridfs.GridFsTemplate;

import com.mongodb.Mongo;
import com.mongodb.MongoClient;

/**
 * Spring MongoDB configuration file
 *
 */
@Configuration
public class SpringMongoConfig extends AbstractMongoConfiguration{

    @Bean
    public GridFsTemplate gridFsTemplate() throws Exception {
        return new GridFsTemplate(mongoDbFactory(), mappingMongoConverter());
    }

    @Override
    protected String getDatabaseName() {
        return "yourdb";
    }

    @Override
    @Bean
    public Mongo mongo() throws Exception {
        return new MongoClient("127.0.0.1");
    }

}

GridFsAppStore.java

package com.example.core;

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;

import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
import org.springframework.data.mongodb.gridfs.GridFsOperations;

import com.example.config.SpringMongoConfig;
import com.mongodb.BasicDBObject;
import com.mongodb.DBObject;

/**
 * GridFs example
 *
 * @author example
 *
 */

public class GridFsAppStore {

    public static void main(String[] args) {

    ApplicationContext ctx =
                     new AnnotationConfigApplicationContext(SpringMongoConfig.class);
    GridFsOperations gridOperations =
                      (GridFsOperations) ctx.getBean("gridFsTemplate");

    DBObject metaData = new BasicDBObject();
    metaData.put("extra1", "anything 1");
    metaData.put("extra2", "anything 2");

    InputStream inputStream = null;
    try {
        inputStream = new FileInputStream("/Users/example/Downloads/testing.png");
        gridOperations.store(inputStream, "testing.png", "image/png", metaData);

    } catch (FileNotFoundException e) {
        e.printStackTrace();
    } finally {
        if (inputStream != null) {
            try {
                inputStream.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }

        System.out.println("Done");
    }

}

Passez en revue la console MongoDB, voyez ce qui est enregistré.

> show dbs
yourdb  0.203125GB

> use yourdb
switched to db yourdb

> show collections
fs.chunks
fs.files
system.indexes

> db.fs.files.find()
{ "_id" : ObjectId("51641c5630045c9b3db35afc"), "chunkSize" : NumberLong(262144),
"length" : NumberLong(4238), "md5" : "9969527cd95a5a573f15e953f0036800", "filename" : "testing.png",
"contentType" : "image/png", "uploadDate" : ISODate("2013-04-09T13:49:10.104Z"),
"aliases" : null, "metadata" : { "extra1" : "anything 1", "extra2" : "anything 2" } }
>

> db.fs.chunks.find()
{ "_id" : ObjectId("51641c5630045c9b3db35afd"),
"files_id" : ObjectId("51641c5630045c9b3db35afc"), "n" : 0,
"data" : BinData(0,"/9j/4AAQSkZJRgABAgAAZ......EQH/9k=") }

Les informations de l'image sont enregistrées dansfs.files, et le fichier de l'image (converti en binaire) est stocké dansfs.chunks, et lié via_id etfiles_id.

2. GridFS - Exemple de lecture (configuration Spring dans un fichier XML)

Lisez le fichier image ci-dessus depuis MongoDB et enregistrez-le sous une autre image.

SpringConfig.xml



    
    

    
        
        
    

GridFsAppStore.java

package com.example.core;

import java.io.IOException;
import java.util.List;

import org.springframework.context.ApplicationContext;
import org.springframework.context.support.GenericXmlApplicationContext;
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.data.mongodb.gridfs.GridFsOperations;

import com.mongodb.BasicDBObject;
import com.mongodb.DBObject;
import com.mongodb.gridfs.GridFSDBFile;

/**
 * GridFs example
 *
 * @author example
 *
 */

public class GridFsAppRead {

    public static void main(String[] args) {

    ApplicationContext ctx =
              new GenericXmlApplicationContext("SpringConfig.xml");
    GridFsOperations gridOperations =
              (GridFsOperations) ctx.getBean("gridFsTemplate");

    List result = gridOperations.find(
               new Query().addCriteria(Criteria.where("filename").is("testing.png")));

    for (GridFSDBFile file : result) {
        try {
            System.out.println(file.getFilename());
            System.out.println(file.getContentType());

            //save as another image
            file.writeTo("/Users/example/Downloads/new-testing.png");
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    System.out.println("Done");

    }
}

Télécharger le code source

Téléchargez-le -SpringMongoDB-GridFs-Example.zip (24 Ko)