3

FineUploaderjQueryの例を機能させようとしています。基本的には、クライアントページからWebサーバーにファイルをアップロードする方法にすぎません。

プロジェクトのGitHubページに、サーバー側でファイルストリームを設定する方法の例があります。

スクリプトからこのHttpPostを呼び出すにはどうすればよいendpointですか?単純なjQueryの例は次のようになります。

$(document).ready(function () {
      $('#jquery-wrapped-fine-uploader').fineUploader({
        request: {
          endpoint: 'WhatToWriteHere??'
        },
        debug: true
      });
    });

では、何を入力しますendpointか?のようなものになると思いますがNamespace.Namespace.ClassName.UploadMethod()、私はそれをいじっていますが、それを機能させることはできません。Firebugでデバッグすると、次のエラーが発生します。

405 Method Not Allowed  
[FineUploader] xhr - server response received for 0
The HTTP verb POST used to access path '/FineUploaderTest/Uploadfolder' is not allowed.

何か案が?

4

1 に答える 1

4

ファイルのアップロードを処理するための汎用HttpHandlerを作成できます。

public class UploadHandler : IHttpHandler
{
    public void ProcessRequest(HttpContext context)
    {
        var request = context.Request;
        var formUpload = request.Files.Count > 0;

        var xFileName = request.Headers["X-File-Name"];
        var qqFile = request["qqfile"];
        var formFilename = formUpload ? request.Files[0].FileName : null;

        var filename = xFileName ?? qqFile ?? formFilename;
        var inputStream = formUpload ? request.Files[0].InputStream : request.InputStream;

        var filePath = Path.Combine(context.Server.MapPath("~/App_Data"), filename);
        using (var fileStream = File.OpenWrite(filePath))
        {
            inputStream.CopyTo(fileStream);
        }

        context.Response.ContentType = "application/json";
        context.Response.Write("{\"success\":true}");
    }

    public bool IsReusable
    {
        get { return true; }
    }
}

その後:

$(document).ready(function () {
    $('#jquery-wrapped-fine-uploader').fineUploader({
        request: {
            endpoint: '/uploadhandler.ashx'
        },
        debug: true
    });
});
于 2013-01-15T09:03:44.873 に答える