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>
注: 这个是很久以前在网上看到的,就整理了下来,但是这么久都没用过,所以也没调试过,你自己试一试研究研究, 再来网上很多博客里,他们写的很详细的,可以去看看
这个是上传文件的html标签,一般用在表单里面,完整写法是<input type='file' name='file' /> 然后php端用$_POST['file']或者$_GET['file']这样接文件
上传的原理是:上传文件直接上传成功,暂存为.tmp格式的文件,一般是接收之后,将文件移动到别的目录
用JSP实现文件上传功能,参考如下:UploadExample.jsp
<%@ page contentType="text/htmlcharset=gb2312"%>
<html>
<title><%= application.getServerInfo() %></title>
<body>
上传文件程序应用示例
<form action="doUpload.jsp" method="post" enctype="multipart/form-data">
<%-- 类型enctype用multipart/form-data,这样可以把文件中的数据作为流式数据上传,不管是什么文件类型,均可上传。--%>
请选择要上传的文件<input type="file" name="upfile" size="50">
<input type="submit" value="提交">
</form>
</body>
</html>
doUpload.jsp
<%@ page contentType="text/htmlcharset=GBK" %>
<%@ page import="java.io.*"%>
<%@ page import="java.util.*"%>
<%@ page import="javax.servlet.*"%>
<%@ page import="javax.servlet.http.*"%>
<html><head><title>upFile</title></head>
<body bgcolor="#ffffff">
<%
//定义上载文件的最大字节
int MAX_SIZE = 102400 * 102400
// 创建根路径的保存变量
String rootPath
//声明文件读入类
DataInputStream in = null
FileOutputStream fileOut = null
//取得客户端的网络地址
String remoteAddr = request.getRemoteAddr()
//获得服务器的名字
String serverName = request.getServerName()
//取得互联网程序的绝对地址
String realPath = request.getRealPath(serverName)
realPath = realPath.substring(0,realPath.lastIndexOf("\\"))
//创建文件的保存目录
rootPath = realPath + "\\upload\\"
//取得客户端上传的数据类型
String contentType = request.getContentType()
try{
if(contentType.indexOf("multipart/form-data") >= 0){
//读入上传的数据
in = new DataInputStream(request.getInputStream())
int formDataLength = request.getContentLength()
if(formDataLength >MAX_SIZE){
out.println("<P>上传的文件字节数不可以超过" + MAX_SIZE + "</p>")
return
}
//保存上传文件的数据
byte dataBytes[] = new byte[formDataLength]
int byteRead = 0
int totalBytesRead = 0
//上传的数据保存在byte数组
while(totalBytesRead <formDataLength){
byteRead = in.read(dataBytes,totalBytesRead,formDataLength)
totalBytesRead += byteRead
}
//根据byte数组创建字符串
String file = new String(dataBytes)
//out.println(file)
//取得上传的数据的文件名
String saveFile = file.substring(file.indexOf("filename=\"") + 10)
saveFile = saveFile.substring(0,saveFile.indexOf("\n"))
saveFile = saveFile.substring(saveFile.lastIndexOf("\\") + 1,saveFile.indexOf("\""))
int lastIndex = contentType.lastIndexOf("=")
//取得数据的分隔字符串
String boundary = contentType.substring(lastIndex + 1,contentType.length())
//创建保存路径的文件名
String fileName = rootPath + saveFile
//out.print(fileName)
int pos
pos = file.indexOf("filename=\"")
pos = file.indexOf("\n",pos) + 1
pos = file.indexOf("\n",pos) + 1
pos = file.indexOf("\n",pos) + 1
int boundaryLocation = file.indexOf(boundary,pos) - 4
//out.println(boundaryLocation)
//取得文件数据的开始的位置
int startPos = ((file.substring(0,pos)).getBytes()).length
//out.println(startPos)
//取得文件数据的结束的位置
int endPos = ((file.substring(0,boundaryLocation)).getBytes()).length
//out.println(endPos)
//检查上载文件是否存在
File checkFile = new File(fileName)
if(checkFile.exists()){
out.println("<p>" + saveFile + "文件已经存在.</p>")
}
//检查上载文件的目录是否存在
File fileDir = new File(rootPath)
if(!fileDir.exists()){
fileDir.mkdirs()
}
//创建文件的写出类
fileOut = new FileOutputStream(fileName)
//保存文件的数据
fileOut.write(dataBytes,startPos,(endPos - startPos))
fileOut.close()
out.println(saveFile + "文件成功上载.</p>")
}else{
String content = request.getContentType()
out.println("<p>上传的数据类型不是multipart/form-data</p>")
}
}catch(Exception ex){
throw new ServletException(ex.getMessage())
}
%>
</body>
</html>
运行方法,将这两个JSP文件放在同一路径下,运行UploadExample.jsp即可。
欢迎分享,转载请注明来源:夏雨云
评论列表(0条)