基本可以告别文件服务器了,今天来看下mongodb为我们提供的文件存储;这里依然使用的是spingdatamongodb;不同的是,之前操作都是用mongoTemplete 今天用另一个模板接口, GridFsTemplate
废话不多说,直接上代码
yml配置文件
spring
data:
mongodb:
host: **.**.**.**
port: 27017
database: ***
username: ***
password: ***
pom 引入mongodb坐标
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>
对了,还引入了hutool
创建一个test测试类,直接搞起
@SpringBootTest
class MongodbImageTest {
@Autowired
GridFsTemplate gridFsTemplate;
@Test
public void saveImage() {
// 电脑上一个文件的绝对路径
BufferedInputStream inputStream = FileUtil.getInputStream(FileUtil.file("C:\\Users\\DELL\\Desktop\\123.jpg"));
ObjectId store = gridFsTemplate.store(inputStream, RandomUtil.randomNumbers(4), "jpg");
System.out.println(store.toHexString());
}
@Test
public void queryImage() throws IOException {
String fileId = "62a196ce924e827547842643";
GridFSFile fsFile = gridFsTemplate.findOne(new Query(Criteria.where("_id").is(new ObjectId(fileId))));
GridFsResource resource = gridFsTemplate.getResource(fsFile);
//创建GridFsResource用于获取流对象
String fileName = fsFile.getFilename();
Object contentType = fsFile.getMetadata().get("_contentType");
InputStream inputStream = resource.getInputStream();
File file = FileUtil.file("C:\\Users\\DELL\\Desktop\\" + fileName + "." + contentType + "");
FileUtil.writeFromStream(inputStream, file);
}
@Test
public void deleteImage() {
String fileId = "62a196ce924e827547842643";
Query query = Query.query(Criteria.where("_id").is(fileId));
// 查询单个文件
GridFSFile gfsfile = gridFsTemplate.findOne(query);
gridFsTemplate.delete(query);
}
}
[MongoDB]分片, 当你一台文件服务器硬盘不够的时候, 分片轻而易举解决这个问题
批量文件, 图片, 视频, 音频 考虑采用 MongoDB gridfs