Asp.net Ajax文件上载处理程序在请求时始终为零

Asp.net Ajax文件上载处理程序在请求时始终为零,asp.net,ajax,asp.net-ajax,jquery-file-upload,ashx,Asp.net,Ajax,Asp.net Ajax,Jquery File Upload,Ashx,我在webforms上使用处理程序(.ashx)通过ajax上传文件,在处理程序上检索文件数据时遇到了一些问题 下面是我的javascript代码 $('#myImageButton').change(function (e) { debugger; var filename = $(this).val(); var lastIndex = filename.lastIndexOf("\\"); if (lastIndex >= 0) {

我在webforms上使用处理程序(.ashx)通过ajax上传文件,在处理程序上检索文件数据时遇到了一些问题

下面是我的javascript代码

 $('#myImageButton').change(function (e) {

    debugger;

    var filename = $(this).val();
    var lastIndex = filename.lastIndexOf("\\");
    if (lastIndex >= 0) {
        filename = filename.substring(lastIndex + 1);
    }

    var fileUpload = $("#myImageButton").get(0);
    var files = fileUpload.files;

    var data = new FormData();
    for (var i = 0; i < files.length; i++) {
        data.append(files[i].name, files[i]);
    }

    $.ajax({
        type: 'POST',
        url: 'FileUploadHandler.ashx',
        contentType: false,
        processData: false,
        data: "{ 'context': '" + data + "', 'flag': 'some_flag_here' }",
        success: function (msg) {
            alert(msg);
            $('#tbImagePath2').val(filename);
        },
        error: function (xhr, status, error) {
            debugger;
            var err = eval("(" + xhr.responseText + ")");
            alert(err.Message);
        }
    });
});
$('#myImageButton')。更改(函数(e){
调试器;
var filename=$(this.val();
var lastIndex=filename.lastIndexOf(“\\”);
如果(lastIndex>=0){
filename=filename.substring(lastIndex+1);
}
var fileUpload=$(“#myImageButton”).get(0);
var files=fileUpload.files;
var data=new FormData();
对于(var i=0;i
我已经检查了我的javascript代码,代码中没有任何错误。 文件数据填充时没有任何错误

问题是,当它调用处理程序(我的ashx文件)中的方法时,它会在方法的开始处遇到断点,下面是处理程序方法

public void ProcessRequest(HttpContext context)
    {
        if (context.Request.Files.Count > 0)
        {
            HttpFileCollection files = context.Request.Files;
            string flag = context.Request["flag"].ToString();
            string fname = String.Empty;

            for (int i = 0; i < files.Count; i++)
            {
                HttpPostedFile file = files[i];
                fname = context.Server.MapPath("~/Images/" + file.FileName);
                file.SaveAs(fname);

                switch (flag)
                {
                    //some stuff here
                }
            }
        }
        //context.Response.ContentType = "text/plain";
        //context.Response.Write("File(s) Uploaded Successfully!");
    }
public void ProcessRequest(HttpContext上下文)
{
如果(context.Request.Files.Count>0)
{
HttpFileCollection files=context.Request.files;
字符串标志=context.Request[“flag”].ToString();
string fname=string.Empty;
对于(int i=0;i
问题是上传的文件没有记录在上下文请求中,好像文件本身没有发送给处理程序来处理(计数总是零)

另外,在ajax上声明的标志也不会记录在上下文请求中

那么,如何在请求中读取图像/文件和标志

问候


平庸的家伙

在ajax帖子配置中设置“数据”选项的方式似乎有些奇怪。此外,还可以尝试将“标志”添加到formdata

试一试:

  //...after adding your file(s)
  data.append('flag','some_flag_here');

  $.ajax({
    url  : 'FileUploadHandler.ashx',
    type : 'POST',
    data : data,
    contentType : false,
    processData : false,
    //...etc
  });

另一位同事也有同样的问题,你可以。

在jquery代码中,你是否尝试过这样设置数据
data:data
而不是将其设置为json字符串
{'context':“+data+”,'flag':'some_flag_here'}