MVC4.5WebApiプロジェクトで500内部サーバーエラーが発生します。GETを使用してWebサービスを正常に呼び出すことができ、Idを使用してGETを呼び出すことができます。しかし、ファイルをPOSTすると、エラーが発生します。にブレークポイントを設定して、Application_BeginRequest()
最初にOPTIONSリクエストを受信し、次にPOSTを受信していることを確認できます。コントローラのメソッドが呼び出されApplication_Error()
ておらず、Global.asax.csにもヒットしないメソッドを追加しました。htmlページはCORSを実行していますが、ThinkTecture.IdentityModelを使用してすでに処理しています。私はファイルのアップロードのためにここのコードに従っています。
何か案は?
クライアントコードは次のとおりです。
<script type="text/javascript">
var UploadDocument = function () {
var url = sessionStorage.getItem("url");
var auth = sessionStorage.getItem("auth");
var data = new FormData();
jQuery.each($('#fileToUpload')[0].files, function (i, file) {
data.append('file-' + i, file);
});
jQuery.support.cors = true;
$.ajax({
type: "POST",
url: url,
data: data,
cache: false,
processData: false,
contentType: false,
//dataType: "json",
headers: { Authorization: 'Basic ' + auth },
crossDomain: true,
success: function (data, textStatus, jqXHR) {
alert('Success');
},
error: function (jqXHR, textStatus, errorThrown) { alert('Error: ' + textStatus + ' ' + errorThrown.message); }
});
};
</script>
私のコントローラーコードは次のようになります。
public int Post(HttpPostedFileBase FileToUpload)
{
// Do stuff with the file
}
リクエストとレスポンスは次のようになります。
Request URL:http://localhost:51234/api/TaxDocument
Request Method:POST
Status Code:500 Internal Server Error
Request Headers
Accept:*/*
Accept-Charset:ISO-8859-1,utf-8;q=0.7,*;q=0.3
Accept-Encoding:gzip,deflate,sdch
Accept-Language:en-US,en;q=0.8
Authorization:Basic YmNhbGxlbjpuZWxsYWM=
Connection:keep-alive
Content-Length:2054044
Content-Type:multipart/form-data; boundary=----WebKitFormBoundaryIGzPKhvRVwFXbupu
Host:localhost:51234
Origin:http://localhost:52386
Referer:http://localhost:52386/Upload.html
User-Agent:Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.4 (KHTML, like Gecko) Chrome/22.0.1229.94 Safari/537.4
Response Headers:
Access-Control-Allow-Credentials:true
Access-Control-Allow-Origin:http://localhost:52386
Cache-Control:no-cache
Content-Length:1133
Content-Type:application/json; charset=utf-8
Date:Tue, 06 Nov 2012 21:10:23 GMT
Expires:-1
Pragma:no-cache
Server:Microsoft-IIS/8.0
X-AspNet-Version:4.0.30319
X-Powered-By:ASP.NET
X-SourceFiles:=?UTF-8?B?QzpccHJvamVjdHNcU2F2ZU15VzJcU2F2ZU15VzIuV2Vic2VydmljZVxhcGlcVGF4RG9jdW1lbnQ=?=