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

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

....首先..

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

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

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

至Access...就是

对象

字段....

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

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

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

图片上传到数据库要用到

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

1.限制文件上传类型只能是图片

function checkFileType(name,file){

var extArray = new Array(".doc",".docx")

var allowSubmit = false

if (!file){

return

}

while (file.indexOf("\\") != -1){

file = file.slice(file.indexOf("\\") + 1)

}

var ext = file.slice(file.indexOf(".")).toLowerCase()

for (var i = 0i <extArray.lengthi++) {

if (extArray[i] == ext){

allowSubmit = true

break

}

}

if(!allowSubmit){

alert("只能上传以下格式的文件:"+ (extArray.join("")) + "\n请重新选择再上传.")

document.getElementById(name).value = ""

}

}

其中:extArray是要求文件类型。可自行定义。

2.引入jQuery外部文件

jquery-2.1.4.min.js

3.编写js代码

$(function () {

$('#txtfilePath1').uploadReview({

width: 350,

height: 350,

target: '#uploadReview1_content'

})

})

其中:txtfilePath1是input:file。width,height是预览图片的宽度和高度。target是显示预览图片的位置。

4.编写jsp页面代码

<body>

<input type="text" class="yourClassName" name="filePath1" id="filePath1"/>

<input type="file" id="txtfilePath1" name="txtfilePath1" style="display:none">

<input type="button" onclick="txtfilePath1.click()" id="fileup1" name="fileup1" class="searchThing"value="上传">

</body>

注: 这个是很久以前在网上看到的,就整理了下来,但是这么久都没用过,所以也没调试过,你自己试一试研究研究, 再来网上很多博客里,他们写的很详细的,可以去看看

用smartupload 控件来完成 你百度下一大堆的例子,算了我帮你百度,不然你分不给我,要记的给我呀,至于保存在数据库中,你可以用年月日时分秒这样的格式生成一个文件存放目录,将图片的路径保存到数据库中

<%@ page language="java" contentType="text/htmlcharset=GB2312" pageEncoding="GB2312"%>

<%@ page language="java" import="java.io.*"%>

<%@ page language="java" import="com.jspsmart.upload.*"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

<html>

<head>

<meta http-equiv="Content-Type" content="text/htmlcharset=GB2312">

<title>文件上传Bean</title>

</head>

<body>

<jsp:useBean id="mySmartUpload" scope="page" class="com.jspsmart.upload.SmartUpload" />

<FORM METHOD="POST" ACTION="Ex7_7.jsp" ENCTYPE="multipart/form-data">

<INPUT TYPE="FILE" NAME="FILE1" SIZE="50"><BR>

<INPUT TYPE="FILE" NAME="FILE2" SIZE="50"><BR>

<INPUT TYPE="FILE" NAME="FILE3" SIZE="50"><BR>

<INPUT TYPE="FILE" NAME="FILE4" SIZE="50"><BR>

<INPUT TYPE="SUBMIT" VALUE="Upload">

</FORM>

<%

//上传文件计数

int count=0

//初始化,传入pageContext内置变量

mySmartUpload.initialize(pageContext)

//允许上传的文件类型

mySmartUpload.setAllowedFilesList("htm,html,txt,jar,")

//或者设定拒绝上传的文件类型

// mySmartUpload.setDeniedFilesList("exe,bat,jsp")

// 拒绝的物理路径

// mySmartUpload.setDenyPhysicalPath(true)

// 设置文件最大为 50000 bytes

mySmartUpload.setMaxFileSize(50000)

// 允许一次最多上载文件大小不超过 200000 bytes

// mySmartUpload.setTotalMaxFileSize(200000)

try {

// 上传 *** 作

mySmartUpload.upload()

//以原文件名存储在web服务器虚拟路径下

//返回上传的文件数

count = mySmartUpload.save("/Upload", mySmartUpload.SAVE_VIRTUAL)

} catch (Exception e){

//输出意外信息

out.println("<b>Wrong selection : </b>" + e.toString())

}

// 显示文件上载数

out.println(count + " file(s) uploaded.")

%>

</body>

</html>


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

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

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

发表评论

登录后才能评论

评论列表(0条)

    保存