我正在尝试使用PHP将GET请求中的OData参数发送到RESTful API。对此服务的格式正确的OData请求如下所示:
https://myapi.org/endpoint?filter=family_name eq 'Doe'
似乎我应该在发送请求之前将这些变量附加到CURLOPT_URL
的末尾,但API服务似乎没有收到OData。
$ch = curl_init();
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_TIMEOUT, 100);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('OSDI-API-Token:xxxxxxxxxxxx'));
curl_setopt($ch, CURLOPT_URL, "https://myapi.org/endpoint?filter=family_name eq 'Doe'");
$response = curl_exec($ch);
curl_close($ch);
echo "<pre>";
print_r($response);
echo "</pre>";
输出为NULL
。考虑到具有相同标题和相同Odata URL的相同请求在API的浏览器中搜索并找到正确的数据,这似乎是一个奇怪的回应。
有人可以确认这是否是通过cURL请求发送OData参数的正确方法?
答案 0 :(得分:7)
将OData参数直接附加到CURLOPT_URL
不起作用,因为它不会形成有效的URL。空格和引号需要转义为family_name%20eq%20%27Doe%27
或family_name+eq+%27Doe%27
。
更简单的方法是在设置http_build_query()
之前使用CURLOPT_URL
将参数附加到网址:
$ch = curl_init();
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_TIMEOUT, 100);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('OSDI-API-Token: xxxxxxxxxx'));
$api_request_parameters = array('filter'=>"family_name eq 'Doe'");
$api_request_url = "https://myapi.org/endpoint";
$api_request_url .= "?".http_build_query($api_request_parameters);
$curl_setopt($ch, CURLOPT_URL, $api_request_url);
$response = curl_exec($ch);
curl_close($ch);
答案 1 :(得分:0)
我知道这个问题已经关闭了一段时间,但只是为了用上面的更多点来补充答案,如果您要使用http_build_query(),则需要在过滤器键中声明'$',例如:< /p>
$api_request_parameters = array ('$filter' => "family_name eq 'Doe'");
$api_request_url. = "?". http_build_query ($ api_request_parameters);
如果你在过滤器中声明没有'$',过滤器将无法正常工作,返回的将是所有记录,在某些情况下可能会返回错误。
如果你选择不使用 http_build_query() 你需要转义所有的空格,例如,假设请求是这样的:
https://myapi.org/endpoint?filter=family_name eq 'Doe test 1234'
参数如下所示:
https://myapi.org/endpoint?filter=family_name+eq+%27Doe%20test%201234%27