spring配置mongodb使用gridfs

参考的博文(相当详细):http://www.baeldung.com/spring-data-mongodb-gridfs

参考spring mongodb的官方文档:https://docs.spring.io/spring-data/mongodb/docs/2.0.2.RELEASE/reference/html/#gridfs


参考spring-data官网的配置

<?xml version="1.0" encoding="UTF-8"?>  
<beans xmlns="http://www.springframework.org/schema/beans"  
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xmlns:p="http://www.springframework.org/schema/p"   
    xmlns:mongo="http://www.springframework.org/schema/data/mongo"    
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.3.xsd
            http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd  
            http://www.springframework.org/schema/data/mongo http://www.springframework.org/schema/data/mongo/spring-mongo.xsd 
            http://www.springframework.org/schema/data/repository http://www.springframework.org/schema/data/repository/spring-repository-1.5.xsd">  
         
	<!-- mongodb 版本3.4.7 -->
	<!--mongodb credentials的配置形式是:用户名:密码@默认数据库  -->
	<!-- <mongo:mongo-client id="mongoClient" host="${db.host}" port="${db.port}" credentials="${db.user}:${db.pwd}@${db.name}"></mongo:mongo-client> -->
    
    <!-- replica-set 副本集连接 -->
    <!-- replica-set格式:ip1:port,ip2:port -->
	<mongo:mongo-client id="mongoClient" replica-set="${db.replica-set}" credentials="${db.user}:${db.pwd}@${db.name}">
		<mongo:client-options
                connections-per-host="100"
        />
	</mongo:mongo-client>
	
	
	<mongo:mapping-converter id="converter" />
	
	
	<mongo:db-factory id="mongoDbFactory" dbname="${db.name}" mongo-ref="mongoClient"/>
    
    <!-- 声明mongoTemplate -->
    <bean id="mongoTemplate" class="org.springframework.data.mongodb.core.MongoTemplate">
        <constructor-arg ref="mongoDbFactory" />
    </bean>
    
    <!-- 声明gridFsTemplate -->
    <bean id="gridFsTemplate" class="org.springframework.data.mongodb.gridfs.GridFsTemplate">
    	<constructor-arg ref="mongoDbFactory" />
    	<constructor-arg ref="converter" />
  	</bean>
      
</beans>


属性文件

db.port=27017
db.host=127.0.0.1
db.user=dev
db.pwd=123456
db.name=isdb
db.replica-set=127.0.0.1:27017



单元测试例子
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.Date;

import javax.annotation.Resource;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.data.mongodb.MongoDbFactory;
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.GridFsCriteria;
import org.springframework.data.mongodb.gridfs.GridFsOperations;
import org.springframework.data.mongodb.gridfs.GridFsResource;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

import com.bluedon.useradmin.datainteraction.commontype.CollectionName;
import com.bluedon.useradmin.datainteraction.model.bd.BDCommendLatitude;
import com.bluedon.useradmin.datainteraction.model.bd.metadata.BDCommend;
import com.bluedon.useradmin.datainteraction.util.FileUtils;
import com.mongodb.WriteConcern;
import com.mongodb.client.gridfs.GridFSBuckets;
import com.mongodb.client.gridfs.GridFSFindIterable;
import com.mongodb.client.gridfs.model.GridFSFile;

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = { "classpath*:/application-context-test.xml"})
public class mongodbTest {
	@Resource  
    protected MongoTemplate mongoTemplate;
	
	@Resource
    GridFsOperations gridOperations;
	
	@Resource
	MongoDbFactory mongodbFactory;
	
	private String collectionName = CollectionName.BD_CommendLatitude;
	
	private void insert(BDCommendLatitude object) throws Exception {
		mongoTemplate.insert(object, collectionName);
	}
	
	@Test
	public void test() throws Exception {
		mongoTemplate.setWriteConcern(WriteConcern.ACKNOWLEDGED);
		Date start = new Date();
		int i=0;
		while(i<10000) {
			i++;
			BDCommendLatitude obj = new BDCommendLatitude();
			
			BDCommend commend = new BDCommend();
			commend.setBzjlbh("123");
			commend.setHjrq(new Date());
			commend.setJlbfz("123456");
			commend.setJlhdz("456132");
			commend.setJlmc("123456");
			commend.setJlwh("123456");
			
			obj.setCommend(commend);
			insert(obj);
			System.out.println("插入完成:"+i);
		}
		Date end = new Date();
		System.out.println("执行完毕,用时(秒):" + (end.getTime() - start.getTime()) / 1000);
	}
	
	@Test
	public void storeFileToGridFs() throws IOException {

		BDCommend commend = new BDCommend();
		commend.setBzjlbh("123");
		commend.setHjrq(new Date());
		commend.setJlbfz("123456");
		commend.setJlhdz("456132");
		commend.setJlmc("123456");
		commend.setJlwh("filename.txt");
	    
		String filePath="C:\\Users\\liu\\Desktop\\待办.txt";
		File sourcefile = new File(filePath);
		// 读取文件内容 (输入流)  
		InputStream out = new FileInputStream(sourcefile);
		
		//上传文件,存储到gridfs
        String id = gridOperations.store(out, "filename.txt").toString();
        
        //查找上传的文件
        GridFSFile gridFsdbFile = gridOperations.findOne(new Query(GridFsCriteria.where("_id").is(id)));
        
        //通过ID获取资源文件
        InputStream downloadStream = GridFSBuckets.create(mongodbFactory.getDb()).openDownloadStream(gridFsdbFile.getObjectId());
        GridFsResource resource = new GridFsResource(gridFsdbFile, downloadStream);
        
        
        //获取流并写入到文件
        InputStream gridStream = resource.getInputStream();
        
        //读取字节流
        ByteArrayOutputStream buffer = new ByteArrayOutputStream();
		byte[] buf = new byte[1024 * 100];// 100KB
		int len = 0;
		while ((len = gridStream.read(buf)) != -1) {
			buffer.write(buf, 0, len);	
		}
		
		FileUtils.writeFile("f:\\aa.txt", buffer.toByteArray());
	}
	
	@Test
	public void findFilesInGridFs() {
	    GridFSFindIterable result = null;
	    result = gridOperations.find(new Query(Criteria.where("filename").is("filename.txt")));
	    
	    //result = gridOperations.findOne(new Query(GridFsCriteria.whereFilename().is( "filename.txt")));
	}
	
	@Test
	public void readFilesFromGridFs() {
		//GridFSFile gridFsdbFile = gridOperations.findOne(new Query(GridFsCriteria.whereFilename().is( "filename.txt")));
		GridFsResource[] txtFiles = gridOperations.getResources("*.txt");
	}
}



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值