200字范文,内容丰富有趣,生活中的好帮手!
200字范文 > 详解表单上传实现 ajax文件异步上传

详解表单上传实现 ajax文件异步上传

时间:2018-07-05 03:01:33

相关推荐

详解表单上传实现 ajax文件异步上传

后端开发|php教程

ajax,实现,上传

后端开发-php教程

项目中用户上传总是少不了的,下面就主要的列举一下表单上传和ajax上传!注意: context.Request.Files不适合对大文件进行操作,下面列举的主要对于小文件上传的处理!本文主要为大家详细介绍了表单上传功能和文件上传功能实现,ajax文件异步上传,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能帮助到大家。

一元夺宝源码免费下载,ubuntu高危漏洞,怎么修改Tomcat服务名,自动浇水爬虫,php后台登陆代码,辽宁媒体抖音seo优化价格咨询lzw

资源下载:

传奇源码 攻击速度,ubuntu xp双启动,银河麒麟tomcat自启动,爬虫 python 驱虫,php实现酒店预订,联邦SEOlzw

A、jQuery官方下载地址:/download/

多码合一收款源码,vscode安装和使用技巧,ubuntu 网卡变化,TOMCAT下载网页翻译,爬虫软件 炒股,eloquent php,河北推广抖音seo公司,经营游戏币网站,手机端下拉框选则地址模板lzw

一.表单上传:

html客户端部分:

选择文件:

一般处理程序服务器端:

public void ProcessRequest(HttpContext context) {context.Response.ContentType = "text/plain";HttpPostedFile file1 = context.Request.Files["file1"];helper.uploadFile(file1, "~/upload/");//这里就是对相应方法进行调用context.Response.Write("ok");//提示执行成功 }

上传代码的封装:

////// 通过form表达提交的文件 /// 文件要保存的虚拟路径 public static void uploadImg(HttpPostedFile file,string virpath) { if (file.ContentLength > 1024 * 1024 * 4){ throw new Exception("文件不能大于4M");}string imgtype = Path.GetExtension(file.FileName);if(imgtype!=".jpg"&&imgtype!=".jpeg") //图片类型进行限制{ throw new Exception("请上传jpg或JPEG图片");}using (Image img = Bitmap.FromStream(file.InputStream)){ string savepath = HttpContext.Current.Server.MapPath(virpath+file.FileName); img.Save(savepath);} } ////// 通过form表达提交的文件 /// 文件要保存的虚拟路径 public static void uploadFile(HttpPostedFile file, string virpath) {if (file.ContentLength > 1024 * 1024 * 6){ throw new Exception("文件不能大于6M");}string imgtype = Path.GetExtension(file.FileName);//imgtype对上传的文件进行限制if (imgtype != ".zip" && imgtype != ".mp3"){ throw new Exception("只允许上传zip、rar....文件");}string dirFullPath= HttpContext.Current.Server.MapPath(virpath);if (!Directory.Exists(dirFullPath))//如果文件夹不存在,则先创建文件夹{ Directory.CreateDirectory(dirFullPath);}file.SaveAs(dirFullPath + file.FileName); }

二.Ajax文件异步上传:

注明:既然有了表单上传为什么又要ajax上传呢?因为表单上传过程中,整个页面就刷新了!ajax异步上传就可以达到只刷新局部位置,下面就简单看看ajax上传吧!

html客户端部分:

$(function () { $("#upload").click(function () { $("#imgWait").show(); var formData = new FormData(); formData.append("myfile", document.getElementById("file1").files[0]);$.ajax({url: "upload.ashx",type: "POST",data: formData,/***必须false才会自动加上正确的Content-Type*/contentType: false,/*** 必须false才会避开jQuery对 formdata 的默认处理* XMLHttpRequest会对 formdata 进行正确的处理*/processData: false,success: function (data) {if (data.status == "true") { alert("上传成功!");}if (data.status == "error") { alert(data.msg);}$("#imgWait").hide();},error: function () {alert("上传失败!");$("#imgWait").hide();} }); }); }); 选择文件:

一般处理程序服务器端:

public void ProcessRequest(HttpContext context) { context.Response.ContentType = "text/html"; if (context.Request.Files.Count > 0) { HttpPostedFile file1 = context.Request.Files["myfile"]; helper.uploadFile(file1, "~/upload/"); //这里引用的是上面封装的方法 WriteJson(context.Response, "true", ""); } else { WriteJson(context.Response, "error", "请选择要上传的文件"); } }

json代码封装:

public static void WriteJson(HttpResponse response,string status1, string msg1, object data1 = null) {response.ContentType = "application/json";var obj = new { status = status1, msg = msg1, data = data1 };string json = new JavaScriptSerializer().Serialize(obj);response.Write(json); }

Ajax之文件异步上传的多种方法

原生js实现文件异步上传的方法

php+ajax实现异步上传图文功能详解

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。