html5Upload+css3+Servlet+Apache DiskFileItemFactory实现文件拖拽上传

Cc_Davis_cC 2016-08-26 02:19:08
/**
* 页面上显示需要上传的文件
* @private
*/
function _showUploadFile(file)
{
var reader = new FileReader();
console.log(file)
// console.log(reader);

//判断文件类型
if (file.type.match(/image*/))
{
reader.onload = function (e)
{
var formData = new FormData();
console.info("1:"+formData);
console.info(formData);
var li = $("#template li").clone();
var img = li.find("img");
var progress = li.find(".progress");
var percentage = li.find(".percentage");
percentage.text("0%");
img.attr("src", e.target.result);
$("ul", $(_uploadEle)).append(li);
$(_uploadEle).find("li").size() == 10 && $(_uploadEle).width(($(_uploadEle).width() + 8) + "px").css("overflow", "auto");
console.info(file);
//formData.uploadFile = file;
formData.append("uploadFile", file);

//上传文件到服务器
_uploadToServer(formData, li, progress, percentage);

};
reader.readAsDataURL(file);
}
else
{
console.log("此" + file.name + "不是图片文件!");
}
}

/**
* 上传文件到服务器
* @private
*/
function _uploadToServer(formData, li, progress, percentage)
{
var xhr = new XMLHttpRequest();
xhr.open("POST", "http://localhost:8098/html5Upload/FileUploadServlet.html", true);
xhr.setRequestHeader('X-Requested-With', 'XMLHttpRequest', 'Content-Type', 'multipart/form-data;');
//HTML5新增的API,存储了上传过程中的信息
xhr.upload.onprogress = function (e)
{
var percent = 0;
if (e.lengthComputable)
{
//更新页面显示效果
percent = 100 * e.loaded / e.total;
progress.height(percent );
percentage.text(percent + "%");
percent >= 100 && li.addClass("done");
}
};
xhr.send(formData);
}

以上是js核心代码,关于源码可以去github下载:登录www.github.com搜索html5upload即可
*******************************************************************************************************
@SuppressWarnings("unchecked")
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String folderPath = "D:\\uploadFile";
DiskFileItemFactory factory = new DiskFileItemFactory();
File dirFile = new File(folderPath);
factory.setRepository(dirFile);
ServletFileUpload uploadServlet = new ServletFileUpload(factory);
try {
List<FileItem> lst = uploadServlet.parseRequest(request);
for (FileItem item : lst) {
// 取得上传的文件名
String fileName = item.getName();
if (fileName != null) {
try {
File f = new File(folderPath, fileName);
} catch (Exception e) {
e.printStackTrace();
}
}
try {
item.write(new File(folderPath, fileName));
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
} catch (FileUploadException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}

}

以上是servlet核心代码

声明一下,这里这仅限小文件,不能传大文件,如果说你有大文件上传,可以拿出来交流一下的。
之所以发帖子,是因为之前找到的都是php的,很少又java的。。。
--我要从南走到北,还要从早走到黑;如果你见我有点累,就请你为我倒碗水。


...全文
348 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
Cc_Davis_cC 2016-08-26
  • 打赏
  • 举报
回复

39,087

社区成员

发帖
与我相关
我的任务
社区描述
HTML5是构建Web内容的一种语言描述方式。HTML5是互联网的下一代标准,是构建以及呈现互联网内容的一种语言方式.被认为是互联网的核心技术之一。
社区管理员
  • HTML5社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧