最近在做专业设计,好多同学讨论上传的文件应该以什么形式保存到数据库中
对于这个问题,有两种解决方案
一:将文件copy到项目下一个包中(这里设定的是在专业设计、SSH小项目中),数据库存储文件的路径
二:数据库直接存储文件,比如一些小的图片,如几十K的头像图片等,可以直接转换成二进制,存放到数据库中
第一种解决方案的实现,好多同行已经写了很详细的文章了,在这里放一个链接:
https://blog.youkuaiyun.com/uniquewonderq/article/details/47057641
对于第二种解决方案的实现,在这里记录并且分享一下:
其实很简单,就是接受文件,将文件读取,转换成byte[],然后直接存储到数据库中,代码如下。
假设封装类User有一个photo属性,用来存放头像信息。
读取上传的图片并进行封装:
InputStream in = new FileInputStream("c:/fugang.jpg");
byte[] photo = new byte[in.available()];
in.read(photo);
in.close();
User.setPhoto(photo);
然后将其保存到数据库中就可以了,这里数据库的属性(拿mysql为例)为binary,并且要指定长度,因为binary在 数据库中有好几种保存长度,如果不指定,可能长度不够使用