4

クライアント側とサーバー側の 2 つのプロジェクトがあります。クライアント側のプロジェクトは純粋な htmljs です。サーバー側は ASP.NET MVC 4 と Web Api です。2 つのプロジェクトがあるため、CROS 機能を有効にする必要があります。サーバーのwebconfigに追加しました:

<system.webServer>
 <httpProtocol>
      <customHeaders>
        <add name="Access-Control-Allow-Origin" value="*" />
        <add name="Access-Control-Allow-Headers" value="Content-Type" />
      </customHeaders>
    </httpProtocol>
</system.webServer>

動作している Ajax Post バージョン:

$.post(url, appContext).done(
                function(data, textStatus, jqXHR) {
                    successFn(data, textStatus);
                })
                .fail(
                    function(jqXHR, textStatus, err) {
                        errorFn(err, textStatus);
                    });

動作していないAngular $http Postバージョン:

 $http({
                url: url,
                method: 'POST',
                params: { appContext: appContext },
                headers: {
                    'Content-Type': 'application/x-www-form-urlencoded'
                    /*'Accept': 'text/json'*/}
            }).success(successFn).error(errorFn);

$http を使用すると、次の 2 つのエラーが発生します。

  1. OPTIONS url 405 (メソッドは許可されていません)
  2. POST url 500 (内部サーバー エラー)

ASP.NET MVC メソッドは

[System.Web.Http.HttpPost]
public List<Module> GetModules([FromBody]SessionContext appContext)
{
 return  CreateModules();
}

編集:

Angular モデルの構成:

var emsApp = angular.module('EmsWeb', ['ui.bootstrap']);
emsApp.config(['$routeProvider', '$httpProvider', function($routeProvider, $httpProvider) {

    $httpProvider.defaults.useXDomain = true;
    delete $httpProvider.defaults.headers.common['X-Requested-With'];
}]);

ブラウザに表示される OPTIONS リクエストのヘッダー:

Request URL:http://localhost/EmsWeb/api/ModuleApi/GetModules?appContext=%7B%22globalDate%22%3A%22Mon%2C%2008%20Jul%202013%2013%3A09%3A35%20GMT%22%2C%22userToken%22%3A%22AlexToken%22%7D
Request Method:OPTIONS
Status Code:405 Method Not Allowed

Request Headers
Accept:*/*
Accept-Encoding:gzip,deflate,sdch
Accept-Language:en-US,en;q=0.8
Access-Control-Request-Headers:accept, origin, content-type
Access-Control-Request-Method:POST
Connection:keep-alive
DNT:1
Host:localhost
Origin:http://localhost:50463
Referer:http://localhost:50463/index.html
User-Agent:Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/27.0.1453.116 Safari/537.36
Query String Parametersview sourceview URL encoded
appContext:{"globalDate":"Mon, 08 Jul 2013 13:09:35 GMT","userToken":"AlexToken"}

Response Headers
Access-Control-Allow-Headers:Content-Type
Access-Control-Allow-Origin:*
Cache-Control:no-cache
Content-Length:76
Content-Type:application/json; charset=utf-8
Date:Mon, 08 Jul 2013 13:09:35 GMT
Expires:-1
Pragma:no-cache
Server:Microsoft-IIS/7.5
X-AspNet-Version:4.0.30319
X-Powered-By:ASP.NET

角度のある方法が機能しない理由はありますか?

非常にばかげていることが判明したため、問題を更新します。これは、 data の代わりに params を使用したためです。

 $http({
                url: url,
                method: 'POST',
                params: { appContext: appContext },
                headers: {
                    'Content-Type': 'application/x-www-form-urlencoded'
                    /*'Accept': 'text/json'*/}
            }).success(successFn).error(errorFn);

angular は GetRequest に変換されます。ContentType も必要ありません。実際のコードは

 $http({method: 'POST',
            url: url,                
            data: appCtx,
        }).success(successFn).error(errorFn);

ALMOSTは解決しましたが、angularはまだOPTIONSリクエストを発行していますが、失敗しますが、ポストリクエストは通過します...

そのためのアイデアは大歓迎です

4

3 に答える 3

0

あなたの ajax が機能している場合は、物事の角度側が構成されていないようです。$http を使用する前にこれを追加します (コントローラーのセットアップで)。

$http.defaults.useXDomain = true;

実際の例については、この人の jsfiddle を参照してください: http://jsfiddle.net/ricardohbin/E3YEt/

編集: コメントと質問の編集に加えて、この投稿が役立つ場合があります: http://www.codeguru.com/csharp/.net/net_asp/using-cross-origin-resource-sharing-cors-in-asp .net-web-api.html

于 2013-07-08T14:11:10.177 に答える
0

- get と Post の構文とパラメーターの送信方法を確認してください - 送信先のアクションまたはメソッドで予期される予期されるパラメーターを確認し、送信側と受信側が同じであることを確認してください。

于 2015-12-20T14:15:50.793 に答える