API 筛选器查询不返回包含特殊字符的值



当尝试访问serviceM8 API以搜索客户时,我正在使用以下API请求。端点有效,但我不确定如何处理特殊字符,如 ' 或 &.

API 文档:https://developer.servicem8.com/docs/filtering

因此,如果我调用以下内容:

https://api.servicem8.com/api_1.0/company.json?%24filter=name%20eq%20"BENTON%"

然后我得到以下结果(3 个结果,包括带有特殊字符的结果。

[
{
"uuid": "60791e9a-8c5a-4e2a-aca5-f9625bef7d8b",
"edit_date": "2018-06-20 15:13:53",
"name": "BENTON'S TEST",
},
{
"uuid": "f722b374-e330-42f1-a09e-333b375af1ab",
"edit_date": "2018-07-05 09:46:30",
"name": "Benton's test",
},
{
"uuid": "df01f8ce-a1c9-438b-8954-297b113689ab",
"edit_date": "2018-07-05 17:02:43",
"name": "BENTONS TEST",
}

]

我想尝试过滤的是本顿测试,所以我尝试以下方法,但这不起作用。

https://api.servicem8.com/api_1.0/company.json?%24filter=name%20eq%20"BENTON'S%"
{
"uuid": "df01f8ce-a1c9-438b-8954-297b113689ab",
"edit_date": "2018-07-05 17:02:43",
"name": "BENTONS TEST",
}

我现在的问题是,我如何在此 API 中进行过滤,以便我可以搜索这些特殊字符? 就像本顿的一样。如果我使用 %27 替换不会更改结果的 ' 符号,因为过滤器中的 % 符号似乎被用作搜索参数?

更新

阅读: https://community.dynamics.com/crm/b/mscrmshop/archive/2015/12/21/crm-odata-rest-queries-and-special-characters

我假设 %27 只是无法识别,我应该使用两个单引号,但这也不起作用。如果我在前端应用程序中搜索,搜索"不起作用,但是当我使用\"时,我可以搜索正确的名称。但是在我的查询字符串中使用它不起作用。

请使用&$filter=substringof("BENTON'S",name)而不是&$filter=name eq "BENTON'S"。这将返回包含 Benton 的所有名称。

否则,您也可以使用&$filter=startswith("BENTON'S",name)

最新更新