一、数据库存储
直接把图片的二进制码存到数据库
参考blog:
直接存图片在MySQL上面有两点好处:
- 比较容易做取重,就是相同的图片只存一份.
- 最重要备份使用数据库的备份方式简单.
- 容易管理,去掉无用的图片等.
缺点:
- 不适合超大量存储,数据的存储越大,恢复越麻烦
- 当然一般还是需要前端做更多的物理缓存,而不是靠mysql来直接输出.
二、webRoot下存储
利用上床组件把图片上传到web项目下,再存储图片的相对路径到数据库表中,需生成一个新的不会重复的图片名
缺点:显而易见重新部署项目前需要重新把已上传的图片备份,待部署成功后拷贝到web项目下
三、web项目外存储
顾名思义,把图片上传到web目录外
1.建立存放图片的目录和web项目下一目录之间的联系
例如:Linux系统下,首先把图片上传到项目外一目录
然后把此目录挂载到项目内某一目录下 mount --bind 实际存放图片目录 项目内某一目录
然后把上传图片的相对路径存储到数据库表中
最后在项目中直接访问这个URL获取图片
注意:第一存放图片的目录需有上传权限;
第二在重新部署时,undeploy前先解除挂载 umount 实际存放图片目录 项目内某一目录
待项目上传成功后再重新建立挂载,否则在undeploy时可能丢失已上传的图片
缺点:每次部署前后要进行挂载,解挂载操作,易误操作丢失资源
2.配置虚拟路径
例如使用tomcat时:
首先把图片上传到项目外一目录下
然后在tomcat中配置一个虚拟路径指向上传目录命名为 "/fileUpload" (在/conf/server.xml下配置 Context即可)
然后把上传图片的相对路径存储到数据库表中
再在程序中通过访问这个虚拟路径 "
/fileUpload" + 数据库中存储的相对URL 来获取文件资源
(其实相当于在tomcat下重新启动了一个web项目,然后通过访问此web项目下的图片资源,
这样其实也可以通过 http://ip:port/webProject/ resourse)