ASP.NET MVC上传文件的几种方法

本文介绍三种文件上传的方法:Form表单提交、Ajax.BeginForm及Ajax异步提交,并详细讲解了每种方法的具体实现过程和后端处理逻辑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.Form表单提交

1
2
3
4
5
<p>Form提交</p>
<form action="@Url.Action("SavePictureByForm")" enctype="multipart/form-data" method="post">
    <input id="pic" name="pic" type="file" />
    <input type="submit" value="提交" />
</form>

2.Ajax.BeginForm,原理也是Form表单提交

1
2
3
4
5
6
<p>Ajax.BeginForm</p>
@using(Ajax.BeginForm("SavePictureByForm"nullnew AjaxOptions() { OnSuccess = "PostSuc", OnFailure = "PostFail", HttpMethod = "Post"}, new {enctype = "multipart/form-data"}))
{
   <input type="file" name="pic" id="pic" multiple="multiple" />
   <input type="submit" value="提交" />
}

以上两种方式,在后台用同一种方法可以获取数据: 但是这两种方法会造成页面刷新,有时会影响用户操作.

1
2
3
4
5
6
7
8
9
10
11
public ActionResult SavePictureByForm()
       {
           HttpFileCollectionBase files = Request.Files;
           var file = files[0];
           bool isOk = false;
           string msg = string.Empty;
           //....OtherDO
 
 
           return Content("<script>window.location.href='/home/index';</script>");
       }

3.Ajax提交  用此方法需要用到FileReader类,再获取到文件的Base64数据,将Base64数据Post过去

1
2
3
4
<p>Ajax:以上传图片为例</p>
<input type="file" id="picAjax"/>
<input type="button" id="submitPic" value="提交" />
<img id="selImg"  src="" alt="用作图片预览" />
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
var picString = "";
$(function () {
    $("#picAjax").change(function (e) {
        var file = e.delegateTarget.files[0];
        //在此可以对选择的文件进行判断:文件类型 文件大小等
        //.....
         
        var reader = new FileReader();
        reader.readAsDataURL(file);
        reader.onload = function (ret) {
            picString = reader.result
            //预览图片
            $("#selImg").attr({ "src": picString });
        }
    });
 
    $("#submitPic").click(function () {
        $.ajax("home/SavePicture", {
            type: "post",
            datatype: "json",
            data: picString,
            error: function () { },
            success: function (result) {
                if (result) {
                    alert(result.msg);
                }
            }
        });
    });

后端接收

1
2
3
4
5
6
7
8
9
10
[HttpPost]
       public ActionResult SavePicture(string picString)
       {
           bool isOk = false;
           string msg = string.Empty;
           //其他操作
           //.........
           //.........
           return Json(new { suc = isOk, msg = msg });
       }

第三种方法做到了真正异步提交.但是如果选择的文件较大,可能会出现问题(未测试).

 

对于图片预览 前两种方法也可用base64数据进行图片预览.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值