ajaxFileUpload上传文件后提示下载的问题
在某些版本浏览器下ajaxFileUpload上传文件会提示下载,
1:为什么?
可以观察到,即便返回 JsonResult 在返回的头中也没有任何消息体,直接理解为文本了。
2:解决方案
前端:
function uploadImg(fimgi) {
if ($("#fimg" + fimgi).val().length > 0) {
//alert($("#fimg" + fimgi).val().length);}
else {
alert("请选择图片");
return;
}
$.ajaxFileUpload({
type: 'post',
url: "/product/UploadProductImage?fimgi=" + fimgi,
secureuri: false,
fileElementId: 'fimg' + fimgi,
dataType: "json",
success: function (data) {
alert("上传成功!");
//alert(data.O);
$("#Img" + fimgi).val(data.O);
},
error: function (XMLHttpRequest, textStatus, e) {
alert(textStatus);
alert(e);
}
});
}
后台改为范围ContentResult,且,ContentType = "text/html"。
public ContentResult UploadProductImage(int fimgi)
{
HttpPostedFileBase head = this.Request.Files["fimg"+fimgi];if (head == null)
{
return new ContentResult
{
Content = new JavaScriptSerializer { MaxJsonLength = int.MaxValue }.Serialize(new R() { F = 1, M = "对不起,无上传内容!" }),
ContentType = "text/html"
};
}var supportedTypes = new[] { "jpg", "jpeg", "png", "gif", "bmp" };
var fileExt = System.IO.Path.GetExtension(head.FileName).Substring(1);
if (!supportedTypes.Contains(fileExt))
{
return new ContentResult
{
Content = new JavaScriptSerializer { MaxJsonLength = int.MaxValue }.Serialize(new R() { F = 1, M = "对不起,只能上传 jpg, jpeg, png, gif, bmp!" }),
ContentType = "text/html"
};
}if (head.ContentLength > 1024 * 1024)
{
return new ContentResult
{
Content = new JavaScriptSerializer { MaxJsonLength = int.MaxValue }.Serialize(new R() { F = 1, M = "对不起,大小超出限制1M!" }),
ContentType = "text/html"
};
}var r = new Random();
var filename = Guid.NewGuid().ToString("N") + "." + fileExt;
string path = this.Server.MapPath("~/upload/product");if (!Directory.Exists(path))
{
Directory.CreateDirectory(path);
}var filepath = Path.Combine(path, filename);
head.SaveAs(filepath);
string webPath = "/upload/product/" + filename;return new ContentResult
{
Content = new JavaScriptSerializer { MaxJsonLength = int.MaxValue }.Serialize(new R()
{
F = 0,
M = "上传成功,保存为:" + webPath + "!",
O = webPath
}),
ContentType = "text/html"
};
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器