MongoDB结合Spring存储文件(图片、音频等等)

MongoDB 存储图片等文件有两种方式

(该文章针对的是已经可以使用MONGODB整合Spring的用户)

1.使用MongoTemplate

/**
     * 存储文件 
     * @param collectionName 集合名 
     * @param file 文件 
     * @param fileid 文件id 
     * @param companyid 文件的公司id 
     * @param filename 文件名称
     */
    public void SaveFile(String collectionName, File file, String fileid, String companyid, String filename) {
        try {
            DB db = mongoTemplate.getDb();
            // 存储fs的根节点
            GridFS gridFS = new GridFS(db, collectionName);
            GridFSInputFile gfs = gridFS.createFile(file);
            gfs.put("aliases", companyid);
            gfs.put("filename", fileid);
            gfs.put("contentType", filename.substring(filename.lastIndexOf(".")));
            gfs.save();
        } catch (Exception e) {
            e.printStackTrace();
            System.out.println("存储文件时发生错误!!!");
        }
    }
 
    // 取出文件
    public GridFSDBFile retrieveFileOne(String collectionName, String filename) {
        try {
            DB db = mongoTemplate.getDb();
            // 获取fs的根节点
            GridFS gridFS = new GridFS(db, collectionName);
            GridFSDBFile dbfile = gridFS.findOne(filename);
            if (dbfile != null) {
                return dbfile;
            }
        } catch (Exception e) {
            // TODO: handle exception
        }
        return null;
    }
//抱歉项目案例不能给你,不过这个是向mongodb存取文件的实现代码,希望能帮助到你。
//由GridFSDBFile 可以得到inputStream,这样你就明白了吧。

2.使用GridFsTemplate

 网上找到的第一种方法总结的非常的不好,Spring结合的感觉不够紧密。 谷歌了下参考了下网上的文章。

参考文章


Spring 伪配置

<mongo:mongo host="127.0.0.1" port="27017">
		<mongo:options connections-per-host="200"
			threads-allowed-to-block-for-connection-multiplier="100"
			connect-timeout="1000" max-wait-time="1500" auto-connect-retry="true"
			socket-keep-alive="true" socket-timeout="1500" slave-ok="true"
			write-number="1" write-timeout="0" write-fsync="true" />
	</mongo:mongo>

	<mongo:db-factory dbname="***" username="***"
		password="***" mongo-ref="mongo" />

	<mongo:mapping-converter id="converter"
		db-factory-ref="mongoDbFactory" />

	<!-- 取图函数 -->
	<bean id="gridFsTemplate" class="org.springframework.data.mongodb.gridfs.GridFsTemplate">
		<constructor-arg ref="mongoDbFactory" />
		<constructor-arg ref="converter" />
		<constructor-arg value="****" index="2" /><!-- 表名 -->
	</bean>

      <bean id="abstractMongoDB" class="com.***.AbstractMongoDB"
        abstract="true">
        <property name="mongoTemplate">
            <ref bean="mongoTemplate" />
        </property>
        <property name="gridFsTemplate">
            <ref bean="gridFsTemplate" />
        </property>
     </bean>

Java 伪代码

	List<GridFSDBFile> files = this.getGridFsTemplate().find(null); //查询全部,查询方式和MongoTemplate一样
			
			System.out.println("-----------------");
			 
			   for (GridFSDBFile file: files) {
			     System.out.println(file);
			   }









MongoDB结合Spring存储文件(图片、音频等等),布布扣,bubuko.com

MongoDB结合Spring存储文件(图片、音频等等)

上一篇:在Ubuntu 20.04 LTS Focal Fossa上安装Drupal


下一篇:SQL Server跨库复制表数据错误的解决办法