表单上传功能实现 ajax文件异步上传
发布时间 - 2026-01-11 02:53:39 点击率:次项目中用户上传总是少不了的,下面就主要的列举一下表单上传和ajax上传!注意: context.Request.Files不适合对大文件进行操作,下面列举的主要对于小文件上传的处理!

资源下载:
一、jQuery官方下载地址:https://jquery.com/download/
一.表单上传:
html客户端部分:
<form action="upload.ashx" method="post" enctype="multipart/form-data">
选择文件:<input type="file" name="file1" /><br />
<input type="submit" value="上传" />
</form>
一般处理程序服务器端:
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
HttpPostedFile file1 = context.Request.Files["file1"];
helper.uploadFile(file1, "~/upload/");//这里就是对相应方法进行调用
context.Response.Write("ok");//提示执行成功
}
上传代码的封装:
/// <summary>
/// 上传图片
/// </summary>
/// <param name="file">通过form表达提交的文件</param>
/// <param name="virpath">文件要保存的虚拟路径</param>
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);
}
}
/// <summary>
/// 上传文件
/// </summary>
/// <param name="file">通过form表达提交的文件</param>
/// <param name="virpath">文件要保存的虚拟路径</param>
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客户端部分:
<head>
<script src="jquery-2.1.4.js"></script>
<script>
$(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();
}
});
});
});
</script>
</head>
<body>
选择文件:<input type="file" id="file1" /><br />
<input type="button" id="upload" value="上传" />
<img src="wait.gif" style="display:none" id="imgWait" />
</body>
一般处理程序服务器端:
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);
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# asp.net表单上传
# ajax文件异步上传
# asp.net文件上传
# ajax实现异步文件或图片上传功能
# ajax图片上传
# 图片异步上传
# 更新实例
# ajax 异步上传带进度条视频并提取缩略图
# Ajax异步文件上传与NodeJS express服务端处理
# Ajax异步上传文件实例代码分享
# ajax实现文件异步上传并回显文件相关信息功能示例
# jquery中的ajax异步上传
# Ajax表单异步上传文件实例代码(包括文件域)
# ajax异步实现文件分片上传实例代码
# 上传
# 表单
# 才会
# 的是
# 客户端
# 下载地址
# 又要
# 不存在
# 会对
# 就可
# 请选择
# 不适合
# 少不了
# 上传图片
# 大家多多
# 只允许
# 过程中
# 上传文件
# 文件上传
# 大文件
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?
Win11怎么修改DNS服务器 Win11设置DNS加速网络【指南】
制作旅游网站html,怎样注册旅游网站?
laravel怎么配置和使用PHP-FPM来优化性能_laravel PHP-FPM配置与性能优化方法
如何快速查询域名建站关键信息?
Laravel怎么连接多个数据库_Laravel多数据库连接配置
Laravel如何使用缓存系统提升性能_Laravel缓存驱动和应用优化方案
Laravel如何使用Passport实现OAuth2?(完整配置步骤)
如何用AI一键生成爆款短视频文案?小红书AI文案写作指令【教程】
如何获取PHP WAP自助建站系统源码?
如何在自有机房高效搭建专业网站?
详解jQuery中基本的动画方法
浅谈javascript alert和confirm的美化
Thinkphp 中 distinct 的用法解析
深圳网站制作的公司有哪些,dido官方网站?
如何在服务器上配置二级域名建站?
如何在云主机上快速搭建多站点网站?
Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】
详解阿里云nginx服务器多站点的配置
Linux系统运维自动化项目教程_Ansible批量管理实战
JavaScript模板引擎Template.js使用详解
如何快速完成中国万网建站详细流程?
高防服务器租用指南:配置选择与快速部署攻略
如何快速搭建虚拟主机网站?新手必看指南
java中使用zxing批量生成二维码立牌
Laravel怎么集成Vue.js_Laravel Mix配置Vue开发环境
怎样使用JSON进行数据交换_它有什么限制
Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试
JS中页面与页面之间超链接跳转中文乱码问题的解决办法
浅谈redis在项目中的应用
如何利用DOS批处理实现定时关机操作详解
如何用美橙互联一键搭建多站合一网站?
香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化
齐河建站公司:营销型网站建设与SEO优化双核驱动策略
Java遍历集合的三种方式
如何基于云服务器快速搭建个人网站?
网站制作壁纸教程视频,电脑壁纸网站?
JavaScript如何操作视频_媒体API怎么控制播放
创业网站制作流程,创业网站可靠吗?
高端云建站费用究竟需要多少预算?
EditPlus中的正则表达式实战(6)
制作公司内部网站有哪些,内网如何建网站?
Java解压缩zip - 解压缩多个文件或文件夹实例
湖南网站制作公司,湖南上善若水科技有限公司做什么的?
如何实现javascript表单验证_正则表达式有哪些实用技巧
装修招标网站设计制作流程,装修招标流程?
长沙企业网站制作哪家好,长沙水业集团官方网站?
javascript中数组(Array)对象和字符串(String)对象的常用方法总结
如何挑选优质建站一级代理提升网站排名?

