基于html5+java实现大文件上传实例代码
程序员文章站
2024-03-08 21:49:40
废话不多说了,直接给大家贴代码了,具体代码如下所示:
html代码如下:
废话不多说了,直接给大家贴代码了,具体代码如下所示:
html代码如下:
<body> <input id="fileid" type="file" accept="video/*;capture=camera" onchange="onfile(this)"> <input id="btn" type="button" value="提交"> <script type="text/javascript"> var xhr; function onfile(file) { var fd = new formdata(); fd.append("filetoupload", document.getelementbyid('fileid').files[0]); xhr = new xmlhttprequest(); xhr.open("post", "http://localhost:8889/testup/upservlet"); //xhr.setrequestheader("content-type","charset=utf-8"); xhr.send(fd); xhr.onreadystatechange = processresponse; } function processresponse(){ if(xhr.readystate == 4){ alert("上传结束数据流结束"); if(xhr.status == 200){ var infor = xhr.responsetext; alert("服务器端的响应 = "+infor); } } } </script> </body>
java代码如下所示:
package com.yjm.up; import java.io.file; import java.io.fileoutputstream; import java.io.ioexception; import java.io.inputstream; import java.util.list; import javax.servlet.servletexception; import javax.servlet.http.httpservlet; import javax.servlet.http.httpservletrequest; import javax.servlet.http.httpservletresponse; import org.apache.commons.fileupload.fileitem; import org.apache.commons.fileupload.disk.diskfileitemfactory; import org.apache.commons.fileupload.servlet.servletfileupload; public class upservlet extends httpservlet { public void dopost(httpservletrequest request, httpservletresponse response) throws servletexception, ioexception { // 得到上传文件的保存目录,将上传的文件存放于web-inf目录下,不允许外界直接访问,保证上传文件的安全 string savepath = this.getservletcontext().getrealpath( "/web-inf/upload"); file file = new file(savepath); system.out.println("test。。。。"); // 判断上传文件的保存目录是否存在 if (!file.exists() && !file.isdirectory()) { system.out.println(savepath + "目录不存在,需要创建"); // 创建目录 file.mkdir(); } // 消息提示 string message = ""; try { // 使用apache文件上传组件处理文件上传步骤: // 1、创建一个diskfileitemfactory工厂 diskfileitemfactory factory = new diskfileitemfactory(); // 2、创建一个文件上传解析器 servletfileupload upload = new servletfileupload(factory); // 解决上传文件名的中文乱码 upload.setheaderencoding("utf-8"); // 3、判断提交上来的数据是否是上传表单的数据 if (!servletfileupload.ismultipartcontent(request)) { // 按照传统方式获取数据 return; } // 4、使用servletfileupload解析器解析上传数据,解析结果返回的是一个list<fileitem>集合,每一个fileitem对应一个form表单的输入项 list<fileitem> list = upload.parserequest(request); for (fileitem item : list) { // 如果fileitem中封装的是普通输入项的数据 if (item.isformfield()) { string name = item.getfieldname(); // 解决普通输入项的数据的中文乱码问题 string value = item.getstring("utf-8"); // value = new string(value.getbytes("iso8859-1"),"utf-8"); system.out.println(name + "=" + value); } else {// 如果fileitem中封装的是上传文件 // 得到上传的文件名称, string filename = item.getname(); system.out.println(filename); if (filename == null || filename.trim().equals("")) { continue; } // 注意:不同的浏览器提交的文件名是不一样的,有些浏览器提交上来的文件名是带有路径的,如: // c:\a\b\1.txt,而有些只是单纯的文件名,如:1.txt // 处理获取到的上传文件的文件名的路径部分,只保留文件名部分 filename = filename .substring(filename.lastindexof("\\") + 1); // 获取item中的上传文件的输入流 inputstream in = item.getinputstream(); // 创建一个文件输出流 fileoutputstream out = new fileoutputstream(savepath + "\\" + filename); // 创建一个缓冲区 byte buffer[] = new byte[1024 * 1024]; // 判断输入流中的数据是否已经读完的标识 int len = 0; // 循环将输入流读入到缓冲区当中,(len=in.read(buffer))>0就表示in里面还有数据 while ((len = in.read(buffer)) > 0) { // 使用fileoutputstream输出流将缓冲区的数据写入到指定的目录(savepath + "\\" // + filename)当中 out.write(buffer, 0, len); } out.flush(); // 关闭输入流 in.close(); // 关闭输出流 out.close(); // 删除处理文件上传时生成的临时文件 item.delete(); message = "文件上传成功!"; } } } catch (exception e) { message = "文件上传失败!"; e.printstacktrace(); } request.setattribute("message", message); request.getrequestdispatcher("/message.jsp").forward(request, response); } }
用到的java 包 是 超过1g上传
commons-fileupload-1.2.1.jar
commons-io-1.3.2.jar
//xhr.setrequestheader("content-type","application/octet-stream;charset=utf-8"); 这不能添加