简述
由于博主手头最近的项目中,有很多上传文件的功能需要实现,其中就包括图片的上传和存储,其中也遇到一些问题。
常见的存储方案
常见的存储到磁盘或者第三方的存储服务,如七牛云之类的,比较高端如 使用分布式文件系统进行存储或者使用nfs做存储,但是后面两个实际上我也只是看到过类似的说法,自己本身是没有应用过的,所在在这里也不再概述,毕竟哪有那么多牛逼的项目,遇到了再说,纸上谈兵是没有用。
项目背景
你选择什么样的存储方案,实际上是取决于项目需要和项目成本的,假如说你做的社交类软件,如微博类,那么图片的存储量就很大了,图片本身也很大,并且还需要考虑容量的问题,那你的图片存储肯定不能随便用什么本地磁盘,要是公司没什么实力,或者客户有要求,那图片也不能随便存储,又或者是项目本身是个管理系统类的客户端,那么本身不会存储多少图片,并且图片本身也是设计好的,图片不会太大,那可选择的范围就很大。总而言之,需要考虑的因素很多。
问题分析
我所以在的项目的打包方式是jar包,都是放在docker里面运行的,并且是迭代的部署到客户那边,所以需要考虑以下几个问题:
- docker容器可能经常删除,然后以新的jar包构建新的容器,那么图片不能存到容器里面,不然的话,每次给客户部署,都要重新来。
- 项目本身是运维类项目,类似于管理项目,不会有太多的用户,有很多图面都是一些模板所需要的,而模板的数量本身不会太多,也注定图片本身不会太多。
- 模板都是提前设计好的,图片也是提前传的,所以图片的上传不是实时性的,不用担心图片过大,上传速度慢,影响体验。
- 客户对安全性要求很高,并不允许,图片存储到外网上,所以不能使用第三方服务
可选方案
- 存到客户的本地磁盘,本山图片不会太多,不用考虑扩容问题,但是很可能误删,所以不选择。
- 存储到分布式存储系统,太过于重量级,也不选用。
- 使用nfs做存储,本身没有实现过,并且也不想这么麻烦。
- 直接存储到数据库,方便,避免误删,不需要额外成本。
图片存储到数据库
使用BASE64Encoder来对图片的字节码数据进行编码,然后加上 “data:image/svg+xml;base64,”,与编码后的字符串拼接起来存储到数据库,用时一起返回给前端就可以了。
MultipartFile serviceCatagoryIconFile = deployServiceCatagory.getServiceCatagoryIconFile();
BASE64Encoder base64Encoder = new BASE64Encoder();
String encode = base64Encoder.encode(serviceCatagoryIconFile.getBytes());
System.out.println(serviceCatagoryIconFile.getBytes().length);
deployServiceCatagory.setServiceCatagoryIcon("data:image/svg+xml;base64,"+encode);
deployServiceCatagoryService.insert(deployServiceCatagory);
|