3

我正在尝试通过 ajax 上传一些文本内容,稍后将对其进行解析。那是我的 Javascript 代码:

 $("#fuFile").change(function () {
            var fileInput = document.getElementById("fuFile");
            var file = fileInput.files[0];
            var formdata = new FormData();
            formdata.append('file', file);

            var xhr = new XMLHttpRequest();
            xhr.open("POST", 'testhandler.ashx', true);
            xhr.setRequestHeader("X-Requested-With", "XMLHttpRequest");
            xhr.setRequestHeader("X-File-Name", file.name);
            xhr.setRequestHeader("Content-Type", "application/octet-stream");
            xhr.send(formdata);              

 });

我的文件输入在哪里fuFile,并且testhandler.ashx是获取上传文件的服务器处理程序。(我实际上使用另一个处理程序来解析文件内容。)

但是当我尝试这样做时:

HttpFileCollection fc = context.Request.Files;

它没有返回任何文件。但出于某种原因在 IE 中工作。

但是当我尝试获取输入流时:

    StreamReader stream = new StreamReader(context.Request.InputStream);
    string text = stream.ReadToEnd();

变量变为(textHttp Headers)+ 文件内容。

------WebKitFormBoundaryx16Mw7tnG6JeflIB\r\nContent-Disposition: form-data;name=\"file\"; filename=\"teste export.CSV\"\r\nContent-Type: application/vnd.ms-excel(..file content..)

没关系,但我用过这个插件:http: //valums.com/ajax-upload/

插件只返回了文件内容,因为我可以通过 InputStream 获取内容,我没有收到任何 HTTP 标头。

那是完美的,但我想在不使用插件的情况下制作一个上传脚本。只需上传和解析,返回一些结果。简单快速

所以,我的问题是:如何在任何浏览器中获取由 Ajax XHR 上传的文件内容,只获取文件内容?

4

1 回答 1

0

这对我有用,我认为它可以帮助你

我的js函数:

$("#fuFile").click(function () {
    var fileInput = document.getElementById("fuFile");
    var file = fileInput.files[0];
    var fd = new FormData();
    fd.append("files", file);
    var xhr = new XMLHttpRequest();

    xhr.open("POST", 'http://localhost:63186/UploadFile.ashx');

    xhr.send(fd);

});

我的处理程序:

  string filePath = "~/Files/";

        //write your handler implementation here.
        if (context.Request.Files.Count <= 0)
        {
            context.Response.Write("No file uploaded");
        }
        else
        {
            for (int i = 0; i < context.Request.Files.Count; ++i)
            {
                HttpPostedFile file = context.Request.Files[i];
                 var fileInfo = new FileInfo(file.FileName);
                file.SaveAs(context.Server.MapPath(filePath + fileInfo.Name));
                context.Response.Write("File uploaded");
            }
        }
于 2013-03-18T10:32:23.570 回答