asp.net上传文件

第一种方法

前端:

<div>

单文件上传

<form enctype="multipart/form-data" method="post" action="upload.aspx">

<input type="file" name="files" />

<input type="submit" value="上传" />

</form>

</div>

后端:

using System;

using System.Collections.Generic;

using System.IO;

using System.Linq;

using System.Web;

using System.Web.UI;

using System.Web.UI.WebControls;

public partial class upload_upload : System.Web.UI.Page

{

protected void Page_Load(object sender, EventArgs e)

{

HttpContext context = HttpContext.Current;

context.Response.ContentType = "text/plain";

//获取所有的上传文件

//如果上传的文件超过了4M,则会报异常[超过了最大请求长度。],需要在Web.config配置

HttpFileCollection hfc = context.Request.Files;

//如果是hfc.Count为0,则可以认为是直接请求该ashx处理程序

for (int i = 0; i < hfc.Count; i++)

{

HttpPostedFile hpf = hfc[i];

if (hpf.ContentLength > 0)

{

//大小限制

int maxSize = 2 * 1024 * 1024; //最大是2M(转换为字节)

if (hpf.ContentLength > maxSize)

{

context.Response.Write("上传文件大小超出限制");

return;

}

//扩展名限制

string[] exts = { "image/jpg", "image/jpeg", "image/gif", "image/png" };

if (!exts.Contains(hpf.ContentType.ToLower()))

{

context.Response.Write("必须上传图片文件");

return;

}

string fileName = Path.GetFileName(hpf.FileName);

hpf.SaveAs(context.Server.MapPath("~/upload/" + fileName));

}

}

获取指定name的文件上传

该方式如果是html5的<input type="file" name="files" multiple />则始终是获取第一个上传的文件,multiple

是支持多个文件上传,所以如果上传文件多于一个,则会丢失

//HttpPostedFile hpf = context.Request.Files["files"];

//if (hpf!= null && hpf.ContentLength > 0)

//{

// hpf.SaveAs(context.Server.MapPath("~/UpLoad/" + Path.GetFileName(hpf.FileName)));

//}

context.Response.Write("上传成功");

}

}

第二种方法

前端(1)

<div id="divImg">

<input type="file" class="file" name="file" multiple="multiple" id="file"/>

<button type="button" οnclick="uploadFile()">上传</button>

</div>

js

function uploadFile(){

let files = $("#file").prop("files");

let formData = new FormData();

// 对每个文件进行循环处理

for (let i = 0; i < files.length; i++) {

let file = files[i];

// 添加文件到formData

formData.append('files['+i+']', file, file.name);

}

$.ajax({

url: ctx + "/file/upload",

type: 'POST',

data: formData,

processData: false,

contentType: false,

async: false,

cache: false,

success: function(data) {

console.log(data);

}

});

}

前端(2)

js

<form id="fileUploadForm" enctype="multipart/form-data">

<input type="file" id="fileInput">

<button type="submit">上传</button>

</form>

<script>

$(document).ready(function() {

$('#fileUploadForm').submit(function(e) {

e.preventDefault();

var fileInput = document.getElementById('fileInput');

var file = fileInput.files[0];

var reader = new FileReader();

reader.onload = function(e) {

var fileData = e.target.result;

var formData = new FormData();

formData.append('file', file);

$.ajax({

url: 'upload.php',

type: 'POST',

data: formData,

processData: false,

contentType: false,

success: function(response) {

console.log(response);

},

error: function(xhr, status, error) {

console.error(error);

}

});

};

后端同每一种方法

相关推荐
JohnYan21 分钟前
工作笔记- 记一次MySQL数据移植表空间错误排除
数据库·后端·mysql
程序员清风43 分钟前
阿里二面:Kafka 消费者消费消息慢(10 多分钟),会对 Kafka 有什么影响?
java·后端·面试
CodeSheep1 小时前
宇树科技,改名了!
前端·后端·程序员
hstar95271 小时前
三十五、面向对象底层逻辑-Spring MVC中AbstractXlsxStreamingView的设计
java·后端·spring·设计模式·架构·mvc
楽码1 小时前
AI决策树:整理繁杂问题的简单方法
人工智能·后端·openai
星辰大海的精灵1 小时前
基于Dify+MCP实现通过微信发送天气信息给好友
人工智能·后端·python
import_random1 小时前
[深度学习]5大神经网络架构(介绍)
后端
pengyu2 小时前
【Java设计原则与模式之系统化精讲:壹】 | 编程世界的道与术(实战指导篇)
java·后端·设计模式
陈随易2 小时前
一行代码,将网页元素变成图片!比 html2canvas 快 93 倍的截图神器来了!
前端·后端·程序员
Kookoos2 小时前
性能剖析:在 ABP 框架中集成 MiniProfiler 实现性能可视化诊断
后端·c#·.net·abp vnext·miniprofiler