3

サービス スタック エンドポイントに POST を実行しようとすると、サービスはリクエストを正しくマップしますが、RequestDTO をハイドレートしません。

サービス方法

  public object Post(PostUpdateContactRequest request)
        {
            // Breakpoint below, has hit with no problem. Everything is in the request null though.
            Contacts upd_contact = Contacts.Load(request.Contactid);
            //..other vlaidation/code/etc
            this.m_repository.PostEditContact(upd_contact);
            return new HttpResult() { StatusCode = System.Net.HttpStatusCode.Created };
        }

リクエストDTO

 [Route("/contact/update/","POST")]
    public class PostUpdateContactRequest 
    {
        public virtual long Contactid { get; set; }

        public virtual string Firstname { get; set; }

        public virtual string Lastname { get; set; }

        public virtual string Middlename { get; set; }

        public virtual string Suffix { get; set; }

        public virtual string Homephone { get; set; }

        public virtual string Mobilephone { get; set; }

        public virtual string Workphone { get; set; }

        public virtual string Addressline1 { get; set; }

        public virtual string Addressline2 { get; set; }

        public virtual string City { get; set; }

        public virtual string State { get; set; }

        public virtual string Zipcode { get; set; }

        public virtual string Nickname { get; set; }

        public virtual string Email { get; set; }    
    }

JSON データ (生成されたデータは実際のものではありません)

{ "Addressline1" : "Ap #638-3472 Dolor. Road",
  "Addressline2" : "",
  "City" : "Forest Lake",
  "Contactid" : "1",
  "Email" : "nibh.sit.amet@gravida.ca",
  "Firstname" : "Amela",
  "Homephone" : "222-222-2222",
  "Lastname" : "Airheart",
  "Middlename" : " S",
  "Mobilephone" : "1-111-111-1111",
  "Nickname" : "Thomas",
  "State" : "TN",
  "Suffix" : "NA",
  "Workphone" : "(888)-888-8888",
  "Zipcode" : "32549"
}

何か不足していますか?

さらに調査した後の更新:

Jquery クライアントで ContentType + COR + Datatype が競合しているようです。CORS が使用されていることについて多くのことを読んだ後 (ここにあります)、すべてが「jsonp」の contentType を使用するように指示し、これにより HTTP OPTIONS が発生し、サービス ブレークポイントがヒットしなくなりました。明らかに、動詞が一致しなくなったためです。

contentType 'json' に切り替えると、GET が発生します。繰り返しますが、動詞の不一致。私のサービスは、POST のために、POST を期待しています。

これはすべて、投稿する JSON オブジェクトを取得しようとするためのものです。

使用:

$.ajax({
    url: post_url,
    type: 'POST',
    data: jdata,
    dataType: 'json',
    contentType: 'application/json',
    success: function (data) {
        alert('updated!');
    },
    error: function (xhr, textStatus, error) {
        alert(xhr);
        alert(textStatus);
        alert(error);
    }
});

追加したものを削除し、jquery にこれらのオプションを決定させると、再び POST が返されますが、JSON オブジェクトは返されません。IT は content-type を次のように切り替えます: Content-Type application/x-www-form-urlencoded; 文字セット=UTF-8

私のサービスは何も探しておらず、無視し、決して逆シリアル化しません。しかし、オブジェクトは投稿されようとしています! ヘッダーは次のとおりです。

リクエストヘッダー

POST /AerosMobileInterface/contact/update/ HTTP/1.1
Host: localhost
User-Agent: Mozilla/5.0 (Windows NT 6.1; rv:17.0) Gecko/20100101 Firefox/17.0
Accept: */*
Accept-Language: en-US,en;q=0.5
Accept-Encoding: gzip, deflate
Connection: keep-alive
Content-Type: application/x-www-form-urlencoded; charset=UTF-8
Referer: http://localhost:7072/AjaxDetail.htm?Contactid=98
Content-Length: 387
Origin: http://localhost:7072
Pragma: no-cache
Cache-Control: no-cache

応答ヘッダー

HTTP/1.1 500 NullReferenceException
Cache-Control: private
Content-Type: text/html
Server: Microsoft-IIS/7.5
X-Powered-By: ServiceStack/3.932 Win32NT/.NET, ASP.NET
X-AspNet-Version: 4.0.30319
access-control-allow-headers: content-type
Access-Control-Allow-Origin: *
Date: Sun, 06 Jan 2013 17:13:30 GMT
Content-Length: 9914

POST パラメータ { "Addressline1" : "Ap #638-3472 Dolor. Road", "Addressline2" : "", "City" : "Forest Lake", "Contactid" : "1", "Email" : "nibh.sit .amet@gravida.ca」、「ファーストネーム」:「アメラ」、「ホームフォン」:「222-222-2222」、「ラストネーム」:「エアハート」、「ミドルネーム」:「S」、「携帯電話」:「1 -111-111-1111"、"ニックネーム" : "トーマス"、"都道府県" : "TN"、"サフィックス" : "NA"、"勤務先" : "(888)-888-8888"、"郵便番号" : "32549" }

コンテンツ タイプを動作させることができないようです。この単純なことをするために、Jquery、HTTP、および ServiceStack をハッキングしたくありません。人々が同様の問題を抱えている SO 投稿がたくさんあり、 $.ajax 関数の contentType と DataType を変更すると機能しますが、ここでは機能しません。

ありがとう

更新: - $.ajax 呼び出しで data 引数として渡される変数である jdata は、{} オブジェクトです。console.log(jdata) を実行して、それが実際にオブジェクトであり、文字列や $.ajax を混乱させる他のタイプと間違えられていないことを確認しました。Firebug は有効なオブジェクトであると考えているようで、そのオブジェクトの正しい json プロジェクションを生成します。

$.ajax がそのオブジェクトを REST 呼び出しのクエリ文字列に配置しようとしているようです。サービスを変更して、クエリ文字列の値を受け入れないようにすることができました。これにより、サービスメソッドが起動しなくなります。

4

1 に答える 1

0

したがって、サービススタックでは、RESTエンドポイントへの投稿は、を使用しているときに最も効果的に機能するようですapplication/x-www-form-urlencoded; charset=UTF-8。私は次のようなものでクライアント側を投稿します:

$.ajax({
    url: post_url,
    type: 'POST',
    data: jdata,
    dataType: 'json',  // Accept: application/json
    success: function (data) {
        alert('updated!');
    },
    error: function (xhr, textStatus, error) {
        // according to the docs, this isn't 
        // called for cross domain requests...
    },
    complete: function(xhr, status) {
        if (status != 'success') alert('there was a error!');
    }
});

とはいえ、これではクロスドメインの問題は解決されません。サポートするためにサービススタックを設定する必要がありCORSます。ここに適切な説明があります。

servicestackRESTAPIとCORS

于 2013-03-05T17:19:50.707 に答える