
可以选择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
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)