有没有一种方法可以反序列化Elasticsearch Nest搜索查询?

15

在使用Nest构建Elasticsearch查询时,我希望能够查看发送到Elasticsearch的JSON版本。这可能吗?我想是某种反序列化器。

这是我后续问题的信息:

{
  "_infer": {
    "defaultIndex": "myindex"
  },
  "acknowledged": false,
  "isValid": false,
  "connectionStatus": {
    "success": false,
    "requestMethod": "POST",
    "requestUrl": "http://localhost:9200/myindex",
    "settings": {},
    "request": "{
  "settings": {
    "index": {
      "analysis": {
        "analyzer": {
          "fullTermCaseInsensitive": {
            "tokenizer": "keyword",
            "filter": [
              "standard",
              "lowercase"
            ],
            "type": "custom"
          },
          "fullTerm": {
            "tokenizer": "keyword",
            "filter": [
              "standard"
            ],
            "type": "custom"
          },
          "caseInsensitive": {
            "tokenizer": "lowercase",
            "filter": [
              "standard"
            ],
            "type": "custom"
          }
        }
      }
    }
  },
  "mappings": {
    "searchdata": {
      "properties": {
        "upc": {
          "type": "string"
        },
        "productid": {
          "type": "string"
        },
        "title": {
          "type": "string"
        },
        "store": {
          "type": "string"
        },
        "mediaformat": {
          "type": "multi_field",
          "fields": {
            "mediaformat": {
              "type": "string",
              "analyzer": "fullTermCaseInsensitive"
            },
            "raw": {
              "type": "string",
              "index": "not_analyzed"
            }
          }
        },
        "label": {
          "type": "string"
        },
        "vendor": {
          "type": "string"
        },
        "availabledate": {
          "type": "date"
        },
        "releasedate": {
          "type": "date"
        },
        "lastreturndate": {
          "type": "date"
        },
        "nonreturnable": {
          "type": "string"
        },
        "mpaa": {
          "type": "string"
        },
        "esrb": {
          "type": "multi_field",
          "fields": {
            "esrb": {
              "type": "string",
              "analyzer": "fullTermCaseInsensitive"
            },
            "raw": {
              "type": "string",
              "index": "not_analyzed"
            }
          }
        },
        "csnrflag": {
          "type": "string"
        },
        "cover": {
          "type": "string"
        },
        "size": {
          "type": "string"
        },
        "color": {
          "type": "string"
        },
        "style": {
          "type": "string"
        },
        "qoh": {
          "type": "integer"
        },
        "adult": {
          "type": "integer"
        },
        "salesrank": {
          "type": "integer"
        },
        "listprice": {
          "type": "double"
        },
        "sellingprice": {
          "type": "double"
        },
        "costprice": {
          "type": "double"
        },
        "specialorder": {
          "type": "string"
        },
        "flags": {
          "type": "string"
        },
        "salescategory": {
          "type": "string"
        },
        "artists": {
          "type": "object",
          "properties": {
            "name": {
              "type": "string",
              "analyzer": "fullTerm",
              "index": "not_analyzed"
            },
            "id": {
              "type": "string",
              "analyzer": "fullTerm",
              "index": "not_analyzed"
            }
          }
        },
        "directors": {
          "type": "object",
          "properties": {
            "name": {
              "type": "string",
              "analyzer": "fullTerm",
              "index": "not_analyzed"
            },
            "id": {
              "type": "string",
              "analyzer": "fullTerm",
              "index": "not_analyzed"
            }
          }
        },
        "starring": {
          "type": "object",
          "properties": {
            "name": {
              "type": "string",
              "analyzer": "fullTerm",
              "index": "not_analyzed"
            },
            "id": {
              "type": "string",
              "analyzer": "fullTerm",
              "index": "not_analyzed"
            }
          }
        },
        "credits": {
          "type": "object",
          "properties": {
            "name": {
              "type": "string",
              "analyzer": "fullTerm",
              "index": "not_analyzed"
            },
            "id": {
              "type": "string",
              "analyzer": "fullTerm",
              "index": "not_analyzed"
            }
          }
        },
        "additionaltitles": {
          "type": "string",
          "analyzer": "caseInsensitive"
        },
        "attributes": {
          "type": "string",
          "analyzer": "caseInsensitive"
        },
        "specialty": {
          "type": "multi_field",
          "fields": {
            "specialty": {
              "type": "string",
              "analyzer": "fullTermCaseInsensitive"
            },
            "raw": {
              "type": "string",
              "index": "not_analyzed"
            }
          }
        },
        "genres": {
          "type": "multi_field",
          "fields": {
            "genres": {
              "type": "string",
              "analyzer": "fullTermCaseInsensitive"
            },
            "raw": {
              "type": "string",
              "index": "not_analyzed"
            }
          }
        },
        "theme": {
          "type": "multi_field",
          "fields": {
            "theme": {
              "type": "string",
              "analyzer": "fullTermCaseInsensitive"
            },
            "raw": {
              "type": "string",
              "index": "not_analyzed"
            }
          }
        },
        "price": {
          "type": "multi_field",
          "fields": {
            "price": {
              "type": "string",
              "analyzer": "fullTermCaseInsensitive"
            },
            "raw": {
              "type": "string",
              "index": "not_analyzed"
            }
          }
        },
        "tracks": {
          "type": "string",
          "analyzer": "caseInsensitive"
        },
        "deleted": {
          "type": "string"
        },
        "updatedate": {
          "type": "date"
        },
        "processed": {
          "type": "string"
        },
        "decades": {
          "type": "multi_field",
          "fields": {
            "decades": {
              "type": "string",
              "analyzer": "fullTermCaseInsensitive"
            },
            "raw": {
              "type": "string",
              "index": "not_analyzed"
            }
          }
        },
        "period": {
          "type": "multi_field",
          "fields": {
            "period": {
              "type": "string",
              "analyzer": "fullTermCaseInsensitive"
            },
            "raw": {
              "type": "string",
              "index": "not_analyzed"
            }
          }
        },
        "platform": {
          "type": "multi_field",
          "fields": {
            "platform": {
              "type": "string",
              "analyzer": "fullTermCaseInsensitive"
            },
            "raw": {
              "type": "string",
              "index": "not_analyzed"
            }
          }
        }
      }
    }
  }
}",
    "numberOfRetries": 0,
    "httpStatusCode": 400,
    "serializer": {},
    "successOrKnownError": true
  },
  "infer": {
    "defaultIndex": "myindex"
  }
}
5个回答

22

是的,您可以像这样使用ElasticClient公开的序列化器:

var query = Nest.Query<SomeObject>...
var json = Client.Serializer.SerializeToString(query);

你也可以直接使用Newtonsoft或任何JSON库来序列化查询对象。然而,使用ElasticClient中的序列化器(本质上是包装Newtonsoft)将为您提供NEST将生成的确切JSON。
要了解更多详细信息,请查看NEST中的单元测试,特别是this

我尝试了类似的东西,以查看为什么我的索引没有按照我预期的那样被创建。它看起来还不错,直到我到达响应对象,它只是一堆垃圾字符串。有什么想法吗?请参见我上面的编辑。 - bigerock
那一串垃圾实际上是您的JSON请求,经过Base64编码。 - Greg Marzouka
好的 - 有没有一种方法可以查看它的解码?我真的很紧张。今天早些时候它都正常工作。我不知道我做了什么 - 我真的没想到我做了什么 - 但现在它根本不关注我的映射,而是自己进行简单的动态映射。我一直在注释掉所有内容以查看可能是什么,但没有运气。救命啊! :) - bigerock
好的 - 我弄清楚了,我需要删除整个索引,而不仅仅是类型,并重新开始。关于解码的另一个问题仍然有效。 - bigerock
2
顺便说一下,这段代码对我来说无法工作。出现错误...检测到类型为“Nest.SearchResponse”的属性“response”存在自引用循环。 - bigerock
我已经为您修复了这个问题;使用新的SerializeToString方法替代Serialize。 - Patrick Szalapski

2
我使用SearchDescriptor进行复杂查询,代码如下:
SearchDescriptor<T> sd = new SearchDescriptor<T>()
.From(0).Size(100)
    .Query(q => q
        .Bool(t => t
            .Must(u => u
                .Bool(v => v
                    .Should(
                        ...
                    )
                )
            )
        )
    );

然后得到了反序列化后的JSON,如下所示:

{
  "from": 0,
  "size": 100,
  "query": {
    "bool": {
      "must": [
        {
          "bool": {
            "should": [
              ...
            ]
          }
        }
      ]
    }
  }
}

这很烦人,NEST库应该有一些能够从请求中输出JSON的东西。然而,以下方法对我有效:

using (MemoryStream mStream = new MemoryStream()) {
    client.Serializer.Serialize(sd, mStream);
    Console.WriteLine(Encoding.ASCII.GetString(mStream.ToArray()));
}

NEST库版本:2.0.0.0。 希望更新的版本可以有更简单的方法来获取此信息。


1

0
将以下代码添加到您的 WebApiConfig.cs 文件中:
public static void Register(HttpConfiguration config)
{
    ...
    // ignore circular reference globally
    config.Formatters.JsonFormatter.SerializerSettings.ReferenceLoopHandling = Newtonsoft.Json.ReferenceLoopHandling.Ignore;
    ...
}

然后你应该能够像这样做:

// Return raw
var esObj = await _client.SearchAsync<object>(searchRequest);

// more specific deserialization using Newtonsoft.Json example
foreach (var hit in esObj.Hits) 
{
    var myObj = JsonConvert.DeserializeObject<MyObject>(hit.xxx);
    ...
}

0

对于 Nest 5.3.0:

        var memoryStream = new System.IO.MemoryStream();
        client.Serializer.Serialize(query, memoryStream);
        var jsonQuery = System.Text.Encoding.UTF8.GetString(memoryStream.ToArray());

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接