我正在使用REST API,除其他外,它使用DELETE方法,如下所示:
DELETE /resources/whatever/items/123
要使用PHP访问它,我使用这样的cURL:
self::$curl = curl_init();
curl_setopt_array(self::$curl, array(
CURLOPT_AUTOREFERER => true,
CURLOPT_FOLLOWLOCATION => true,
CURLOPT_RETURNTRANSFER => true,
));
如您所见,我的cURL实例是静态的,将在后续调用中重用.在“内置”请求方法之间切换时,这可以正常工作.例如,在我的get()方法中,我执行以下操作:
curl_setopt_array(self::$curl, array(
CURLOPT_HTTPGET => true,
CURLOPT_URL => self::BASE . 'whatever',
));
然后运行curl_exec().通过CURLOPT_HTTPGET显式设置请求方法,将清除可能的先前CURLOPT_POST.
但是,设置CURLOPT_CUSTOMREQUEST(例如,设置为DELETE)将覆盖任何其他内置请求方法.只要我想删除东西,这很好,但是调用例如curl_setopt(self :: $curl,CURLOPT_HTTPGET,true)将不会重置自定义方法;仍将使用DELETE.
我已经尝试将CURLOPT_CUSTOMREQUEST设置为null,false或空字符串,但这只会导致HTTP请求
/resources/whatever/items/123
即使用空字符串作为方法,后跟空格,然后是路径.
我知道我可以将CURLOPT_CUSTOMREQUEST设置为GET而不做任何问题的GET请求,但我想知道是否有可能重置CURLOPT_CUSTOMREQUEST.
解决方法:
这实际上是PHP中的a bug,因为原始的documentation声明如下:
Restore to the internal default by setting this to NULL.
不幸的是,正如您在the source code中所看到的,选项值在传递给底层库之前会被转换为字符串.
解
我编写了一个解决该问题的pull request,并允许为CURLOPT_CUSTOMREQUEST选项值传递NULL.
上面的补丁需要一些时间才能合并到项目中,因此在您开始使用此选项之前,您必须自己显式设置该方法.
更新
该修复程序已应用于5.5.11和5.6.0(beta1).
标签:php,rest,curl
来源: https://codeday.me/bug/20191007/1868894.html