MongoDB结合Spring存储文件(图片、音频等等)
转自:http://www.linuxidc.com/Linux/2014-04/99742.htmMongoDB 存储图片等文件有两种方式(该文章针对的是已经可以使用MONGODB整合Spring的用户)相关阅读:MongoDB备份与恢复http://www.linuxidc.com/Linux/2012-07/64113.htmCentOS编译安装MongoDB
转自:http://www.linuxidc.com/Linux/2014-04/99742.htm
MongoDB 存储图片等文件有两种方式
(该文章针对的是已经可以使用MONGODB整合Spring的用户)
相关阅读:
MongoDB备份与恢复 http://www.linuxidc.com/Linux/2012-07/64113.htm
CentOS编译安装MongoDB http://www.linuxidc.com/Linux/2012-02/53834.htm
CentOS 编译安装 MongoDB与mongoDB的php扩展 http://www.linuxidc.com/Linux/2012-02/53833.htm
CentOS 6 使用 yum 安装MongoDB及服务器端配置 http://www.linuxidc.com/Linux/2012-08/68196.htm
Ubuntu 13.04下安装MongoDB2.4.3 http://www.linuxidc.com/Linux/2013-05/84227.htm
如何在MongoDB中建立新数据库和集合 http://www.linuxidc.com/Linux/2013-06/85749.htm
MongoDB入门必读(概念与实战并重) http://www.linuxidc.com/Linux/2013-07/87105.htm
《MongoDB 权威指南》(MongoDB: The Definitive Guide)英文文字版[PDF] http://www.linuxidc.com/Linux/2012-07/66735.htm
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;
}
//由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);
}
更多推荐
所有评论(0)