HTML5文件拖拽上传记录
JS文件:
var FileName = "";
var FileStr = "";
(function () {
function $id(id) {
return document.getElementById(id);
}
function Output(msg) {
var m = $id("filedrag");
m.innerHTML = msg + m.innerHTML;
}
function FileDragHover(e) {
e.stopPropagation();
e.preventDefault();
e.target.className = (e.type == "dragover" ? "hover" : "");
}
function FileSelectHandler(e) {
FileDragHover(e);
var files = e.target.files || e.dataTransfer.files;
for (var i = , f; f = files[i]; i++) {
ParseFile(f);
UploadFile(f); //暂时注释
}
}
function ParseFile(file) { //pic类型
if (file.type.indexOf("image") == ) {
var reader = new FileReader();
reader.onload = function (e) {
Output(
"<p><strong>" + file.name + ":</strong><br />" +
'<img src="' + e.target.result + '" /></p>'
);
FileStr=e.target.result;
}
reader.readAsDataURL(file);
}
//文本类型处理
if (file.type.indexOf("text") == ) {
var reader = new FileReader();
reader.onload = function (e) {
Output(
"<p><strong>" + file.name + ":</strong></p><pre>" +
e.target.result.replace(/</g, "<").replace(/>/g, ">") +
"</pre>"
);
}
reader.readAsText(file);
}
}
function uploadProgress(evt) {
if (evt.lengthComputable) {
var percentComplete = Math.round(evt.loaded * / evt.total);
document.getElementById('progressNumber').innerHTML = percentComplete.toString() + '%';
}
else {
document.getElementById('progressNumber').innerHTML = '';
}
}
function UploadFile(file) {
$id("filedrag").innerHTML = ""; //清空当前fileDrg的信息
if (location.host.indexOf("sitepointstatic") >= ) return
var xhr = new XMLHttpRequest();
if (xhr.upload && file.size <= $id("sizebyte").value && file.type == "image/jpeg") {
var o = $id("progress");
var progress = o.appendChild(document.createElement("p"));
// progress.appendChild(document.createTextNode("名称: " + file.name));
// xhr.upload.addEventListener("progress", function (e) {
// var pc = parseInt(100 - (e.loaded / e.total * 100));
// progress.style.backgroundPosition = pc + "% 0";
// }, true);
xhr.onreadystatechange = function (e) {
alert(xhr.readyState);
if (xhr.readyState == ) {
progress.className = (xhr.status == ? "success" : "failure");
}
};
var files = file.name;
FileName=file.name;
}
}
$("#btnUpload").click(function () {
if ($("#fileselect").val() == "") {
if(FileStr==""){
alert("请选择一个图片文件,再点击上传。");
return;
}else{
$.post(
"SaveServer.ashx",
{FileStr:FileStr},
function(data){
alert("成功");
$("#fileselect").val("");
});
}
}else{
$.post(
"SaveServer.ashx",
{FileStr:FileStr},
function(data){
alert("成功");
$("#fileselect").val(""); });
} });
function Init() {
var hh = this;
var fileselect = $id("fileselect"),
filedrag = $id("filedrag")/
fileselect.addEventListener("change", FileSelectHandler, false); var xhr = new XMLHttpRequest();
if (xhr.upload) { filedrag.addEventListener("progress", uploadProgress, false);
filedrag.addEventListener("dragover", FileDragHover, false); //如果鼠标移动但停留在同一个控件中,则引发DragOver事件
filedrag.addEventListener("dragleave", FileDragHover, false); //如果用户移出一个窗口,则引发DragLeave事件
filedrag.addEventListener("drop", FileSelectHandler, false); //完成拖放操作
filedrag.style.display = "block";
upButton.style.display = "block";
} }
if (window.File && window.FileList && window.FileReader) {
Init();
} else {
upButton.style.display = "block";
alert("您的浏览器不支持File API");
}
})();
后台接受页面:
context.Response.ContentType = "text/plain";
string[] aa = context.Request.Form["FileStr"].Split(',');
MemoryStream ms = new MemoryStream(Convert.FromBase64String(aa[]));
Bitmap b = new Bitmap(ms);
string serverPath = System.Web.HttpContext.Current.Server.MapPath("~"); string toFilePath = Path.Combine(serverPath, @"images\headimg\");
string pach = toFilePath + GetImageName() + ".jpg";
b.Save(pach);
context.Response.Write("yes");
context.Response.End();
HTML5文件拖拽上传记录的更多相关文章
- html5 文件拖拽上传
本文首先发表在 码蜂笔记 : http://coderbee.net/index.php/web/20130703/266 html5 文件拖拽上传是个老话题了,网上有很多例子,我一开始的代码也是网 ...
- HTML5应用之文件拖拽上传
使用HTML5的文件API,可以将操作系统中的文件拖放到浏览器的指定区域,实现文件上传到服务器.本文将结合实例讲解HTML5+jQuery+PHP实现拖拽上传图片的过程,来看下HTML5的魅力吧. H ...
- day25—JavaScript实现文件拖拽上传案例实践
转行学开发,代码100天——2018-04-10 今天记录一个利用JavaScript实现文件拖拽上传到浏览器,后天将文件打开的小案例. 基本功能:1点击添加文件 2 文件拖拽添加 html: < ...
- php和js实现文件拖拽上传
Dropzone.js实现文件拖拽上传 http://www.sucaihuo.com/php/1399.html demo http://www.sucaihuo.com/jquery/13/139 ...
- [开源应用]利用HTTPHandler+resumableJs+HTML5实现拖拽上传[大]文件
前言: 大文件传输一直是技术上的一大难点.文件过大时,一些性提交所有的内容进内存是不现实的.大文件带来问题还有是否支持断点传输和多文件同时传输. 本文以resumableJs为例,介绍了如何在ASP. ...
- Nodejs express、html5实现拖拽上传
一.前言 文件上传是一个比较常见的功能,传统的选择方式的上传比较麻烦,需要先点击上传按钮,然后再找到文件的路径,然后上传.给用户体验带来很大问题.html5开始支持拖拽上传的需要的api.nodejs ...
- Dropzone.js实现文件拖拽上传
dropzone.js是一个开源的JavaScript库,提供 AJAX 异步文件上传功能,支持拖拽文件.支持最大文件大小.支持设置文件类型.支持预览上传结果,不依赖jQuery库. 使用Dropzo ...
- html5实现拖拽上传
<html><head> <meta http-equiv="Content-Type" content="text/html; chars ...
- Dropzone.js文件拖拽上传提示Dropzone already attached 解决
最近收到客户的反馈,在操作上传文件有时会出现没有任何.大部分时间是正常. 重现问题后,f12打开后台控制台发现如下提示: Uncaught Error: Dropzone already attach ...
随机推荐
- Mac下面的SecureCRT(附破解方案) 更新到最新的7.2的破解方案
继续更新到7.2的破解.只是升级了下secureCRT到7.2,方法还是不变 相信很多人升级到了7.2的SecureCRT之后原来的破解方案失效了,一直也有人问新的破解方案,发现了,不敢独享放上crt ...
- pip国内源
pip install -i https://pypi.douban.com/simple pyqrcode
- MVC教程二:从控制器中获取URL的值
一.从控制器中获取URL的值有三种方式: 1.使用Request.QueryString[] 例如: string value = Request.QueryString["BookId&q ...
- Spring Boot 日志记录 SLF4J
Spring Boot 日志记录 SLF4J 2016年01月12日 09:25:28 阅读数:54086 在开发中打印内容,使用 System.out.println() 和 Log4j 应当是人人 ...
- 上手并过渡到PHP7(5)——轻量级“集合”迭代器-Generator
轻量级“集合”迭代器-Generator泊学视频链接泊阅文档链接Generator是PHP 5.5加入的新语言特性.但是,它似乎并没有被很多PHP开发者广泛采用.因此,在我们了解PHP 7对Gener ...
- CentOS下的一些基础问题解答
1. 在/etc/passwd中某一行信息为“Linux01:x:505:505:/home/linux12:/bin/bash”,由此可知哪些信息? 用户名为linux01,需要密码登陆,用户ID为 ...
- hdu2147 kiki's game(博弈)
这个是纳什博弈?不知道怎么看的 依据PN图,从左下角開始推 左下角P 最后一行都是PNPNPN 第一列都是 P N P N P 完了填完即可了 #include<cstdio> int m ...
- eclipse项目配置tomcat后浏览器访问不到项目解决方案
先把项目从tomcat溢出,并删除tomcat,然后再次导入 双击: 修改:
- ueditor1.4.3配置过程(包含单独上传文件以及图片的使用),ueditor1.4.3上传配置(转 http://www.bkjia.com/webzh/1001016.html)
这里使用的是ueditor1.4.3的jsp版本的UTF-8版本. 首先下载相应的ueditor,将ueditor文件夹直接拷贝到项目中,文件结构如下所示: 然后将项目要用的jar包导入到lib目录下 ...
- linux cp 复制文件夹
复制文件夹需要添加 -r 或 -R 参数(recursive: 递归的:循环的) 如 cp -r DIR_A DIR_B; 同理,rm 也一样. 如 rm -r DIR_B