jsp中 怎么把图片直接存入数据库中,最好有例子

jsp中 怎么把图片直接存入数据库中,最好有例子,第1张

....首先..

可以选择Apache里面的upload包....

这个是把文件传到服务器上的上传组件....

然后是存到数据库里....那就要看你什么数据库了....比如Oracle..就是Blob

至Access...就是

对象

字段....

存取方法都是不一样的..要分别对待

有个通用方法,你找到图片文件之后,建立输入流,然后创建bytearrayoutputstream,然后从输入流中读字节到后面那个流中,并冲它里面产生字节数组保存到byte字段中

其实建议你不要将图片直接上传到数据库

图片上传到数据库要用到

blob大对象(以oracle为例),这样影响程序性能,你可以将图片上传到指定文件夹,同时将图片保存的路径+文件名上传到数据库,要显示就读取这个这个路径找到图片,然后显示.刚做了个这个代码

String time = new SimpleDateFormat("yyyyMMddHHmmss")

.format(Calendar.getInstance().getTime())// 得到系统时间

// 上传技术

SmartUpload up = new SmartUpload()

// 进行初始化

up.initialize(this.getServletConfig(), request, response)

// 开始上传

try {

up.upload("utf-8")//设置编码方式。

int id = Integer.parseInt(up.getRequest().getParameter("id"))// 商品编号

SmartFiles sf = up.getFiles()// 得到上传的所有图片

SmartFile file = sf.getFile(0)// 根据索引得到上传图片  多个图片可以用循环:

String type = file.getFileExt()// 得到图片后缀名

String folder = "tp/"// 指定文件夹

String path = folder + time + "." + type// 路径

System.out.println(path + "路径")

file.saveAs(request.getRealPath("/") + path)// 保存图片

} catch (Exception e) {

e.printStackTrace()

}

//你搞个邮箱我把SmartUploadjar包 发给你吧。  //设置from提交

/*<form action="SellerServet" method="post"

enctype="multipart/form-data">*/ // 加上 enctype="multipart/form-data

jsp上传图片到数据,在数据库中有一种类型就是blob存储类型,就是用于储存二进制的。在java.sql里面的PreparedStatment有个setBlob()方法存入数据库,还有ResultSet里的getBlob()就是读取,详情你可以看JDBC Blob如何使用。

在jsp里上传图片很少用上述方式存储到数据库中,一般是将图片上传到服务器项目目录文件夹中,然后数据库中保存该图片文件的地址,如/item/upload/images/我上传的图片.jpg


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9969797.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-03
下一篇2023-05-03

发表评论

登录后才能评论

评论列表(0条)

    保存