0

リモートでホストされている odata サービスからデータを取得するために Simple.OData.Client V3 を使用しています。これが私がやっていることですが、不明な理由でodataクライアントが別のリクエストを送信しています

OData クライアントの初期化

public ODataClient CreateClient(bool isPost = true)
{
    var uri = new Uri(ServiceAddress);
    return new ODataClient(new ODataClientSettings(uri)
    {
        Credentials = new NetworkCredential(UserName, Password),
        PayloadFormat = !isPost ? ODataPayloadFormat.Json : ODataPayloadFormat.Atom
    });
}

リクエストを取得

public async Task<GetCustomersResponse> GetCustomers()
{
    var client = CreateClient(false);

    var x = ODataDynamic.Expression;
    var response = await client.For("Catalog_Контрагенты").Top(10).FindEntriesAsync();

    var raw = JsonConvert.SerializeObject(response).ToString();
    var obj = JsonConvert.DeserializeObject<List<CustomerItem>>(raw);

    return new GetCustomersResponse()
    {
        Items = obj
    };
}

送る代わりに

http://odataservice/Catalog_Контрагенты

それは送信します

http://odataservice/Catalog_АвансовыйОтчетПрисоединенныеФайлы

私もこの方法でリクエストを送信しようとしましたが、正しく動作します

public async Task<GetCustomersResponse> GetCustomers()
{
    var client = CreateClient(false);
    var response = await client.FindEntriesAsync("Catalog_Контрагенты?$top=10");            

    var raw = JsonConvert.SerializeObject(response).ToString();
    var obj = JsonConvert.DeserializeObject<List<CustomerItem>>(raw);
    return new GetCustomersResponse()
    {
        Items = obj
    };
}

しかし、前のサンプルの何が問題なのかわかりません。

新しい顧客を更新または追加しようとすると、同じことが起こります。他のリクエストを送信します。

更新 1

これは、正しくないリクエストを送信した場合の Fiddler リクエストです

GET http://hostname/odata/standard.odata/Catalog_%D0%90%D0%B2%D0%B0%D0%BD%D1%81%D0%BE%D0%B2%D1%8B%D0%B9%D0%9E%D1%82%D1%87%D0%B5%D1%82%D0%9F%D1%80%D0%B8%D1%81%D0%BE%D0%B5%D0%B4%D0%B8%D0%BD%D0%B5%D0%BD%D0%BD%D1%8B%D0%B5%D0%A4%D0%B0%D0%B9%D0%BB%D1%8B?$top=10 HTTP/1.1
Accept: application/json, application/xml, application/text
Prefer: return-no-content
Authorization: Basic d2FuZGlvOjEyMzQ=
Host: hostname

応答

HTTP/1.1 200 OK
Content-Length: 185
Content-Type: application/json;charset=utf-8
Server: Microsoft-IIS/7.5
DataServiceVersion: 3.0
X-Powered-By: ASP.NET
Date: Thu, 05 May 2016 06:58:27 GMT

{
"odata.metadata": "http://hostname/odata/standard.odata/$metadata#Catalog_АвансовыйОтчетПрисоединенныеФайлы",
"value": []
}

そして、ここに正しく機能するリクエストがあります

GET http://hostname/odata/standard.odata/Catalog_%D0%9A%D0%BE%D0%BD%D1%82%D1%80%D0%B0%D0%B3%D0%B5%D0%BD%D1%82%D1%8B?$top=10 HTTP/1.1
Accept: application/json, application/xml, application/text
Prefer: return-no-content
Authorization: Basic d2FuZGlvOjEyMzQ=
Host: hostname

応答

HTTP/1.1 200 OK
Content-Length: 28626
Content-Type: application/json;charset=utf-8
Server: Microsoft-IIS/7.5
DataServiceVersion: 3.0
X-Powered-By: ASP.NET
Date: Thu, 05 May 2016 09:40:21 GMT

{
"odata.metadata": "http://hostname/odata/standard.odata/$metadata#Catalog_Контрагенты",
"value": [{
"Ref_Key": "f9210ba9-cbf8-11e1-8023-00155d01bf09",
"DataVersion": "AAAAAAAki8I=",
"DeletionMark": false,
"Parent_Key": "ca28c1de-af9e-11e1-a90b-00155d01bf04",
"IsFolder": false,
"Code": "002879   ",
"Description": "შპს პრაიმ ქემიქალს1",
"ИНН": "404867569",
"КодПоОКПО": "",
"КПП": "",
"НаименованиеПолное": "შპს პრაიმ ქემიქალს",
"БанковскийСчетПоУмолчанию_Key": "00000000-0000-0000-0000-000000000000",
"ДоговорПоУмолчанию_Key": "f9210baa-cbf8-11e1-8023-00155d01bf09",
"КонтактноеЛицо_Key": "00000000-0000-0000-0000-000000000000",
"ФизическоеЛицо_Key": "00000000-0000-0000-0000-000000000000",
"СчетУчетаРасчетовСПокупателем_Key": "552c3f13-4ae6-48a3-a9e2-5ce660958242",
"СчетУчетаАвансовПокупателя_Key": "d38b5a6a-be8b-4c2b-8702-57ea8e02e3e6",
"СчетУчетаРасчетовСПоставщиком_Key": "9d195613-e9b0-4dd9-959d-72fd653ac7fc",
"СчетУчетаАвансовПоставщику_Key": "5060faf9-602e-478c-be88-7145c6f48586",
"Ответственный_Key": "00000000-0000-0000-0000-000000000000",
"Комментарий": "",
"ВестиРасчетыПоДоговорам": true,
"ВестиРасчетыПоДокументам": true,
"ВестиРасчетыПоЗаказам": true,
"ВестиУчетОплатыПоСчетам": true,
"ЮрФизЛицо": "ЮрЛицо",
"АдресЭП": "",
"Нерезидент": false,
"КонтактнаяИнформация": [],
"ДополнительныеРеквизиты": [],
"Parent@navigationLinkUrl": "Catalog_Контрагенты(guid'f9210ba9-cbf8-11e1-8023-00155d01bf09')/Parent",
"ДоговорПоУмолчанию@navigationLinkUrl": "Catalog_Контрагенты(guid'f9210ba9-cbf8-11e1-8023-00155d01bf09')/ДоговорПоУмолчанию",
"СчетУчетаРасчетовСПокупателем@navigationLinkUrl": "Catalog_Контрагенты(guid'f9210ba9-cbf8-11e1-8023-00155d01bf09')/СчетУчетаРасчетовСПокупателем",
"СчетУчетаАвансовПокупателя@navigationLinkUrl": "Catalog_Контрагенты(guid'f9210ba9-cbf8-11e1-8023-00155d01bf09')/СчетУчетаАвансовПокупателя",
"СчетУчетаРасчетовСПоставщиком@navigationLinkUrl": "Catalog_Контрагенты(guid'f9210ba9-cbf8-11e1-8023-00155d01bf09')/СчетУчетаРасчетовСПоставщиком",
"СчетУчетаАвансовПоставщику@navigationLinkUrl": "Catalog_Контрагенты(guid'f9210ba9-cbf8-11e1-8023-00155d01bf09')/СчетУчетаАвансовПоставщику"
}

メタデータ情報

4

1 に答える 1

0

Simple.OData.Client には非ラテン語に関連するバグがあり、アダプターで修正される予定です。

これがこの問題です odata クライアントが間違ったリクエストを送信します

于 2016-05-06T07:25:19.977 に答える