我正在尝试使用REST API
到Curl
&更新ALM中的测试数据PHP
。
Step 1 : Check Lock Status => GET method | response => UNLOCKED
Step 2 : Acquire Lock => POST method | response <entity data XML>
Step 3 : Check Lock Status => GET method | response LOCKED_BY_ME
Step 4 : Checkout Versions | Optional
Step 5 : Update data => PUT method | response = http_code = 200 OK
在第3步之前正常工作,跳过第4步。
我成功到第3步,我收到了LOCKED_BY_ME
的回复。第4步我跳过了,因为我们没有版本控制概念。其中步骤5,当我绑定发送xml数据时,我收到错误415 (Unsupported Media)
,我相信这是因为ALM服务器无法识别我发送的数据。我通过发送“Associative array/XMl/JSON
”来尝试它,但是对于我所有的状态代码我都是415。
这是我的代码。
代码
$url="http://{Host:port}/qcbin/rest/domains/{domainname}/projects/{Projectname}/tests/{id}/lock";
function update_tests()
{
$qc=$this->curl_auth();
$headers = array("DELETE /HTTP/1.1","Content-Type:text/xml");
curl_setopt($qc, CURLOPT_TIMEOUT, $timeout);
curl_setopt($qc, CURLOPT_URL, $url);
curl_setopt($qc, CURLOPT_RETURNTRANSFER, true);
curl_setopt($qc, CURLOPT_COOKIESESSION, true);
curl_setopt($qc, CURLOPT_COOKIEJAR,BASEPATH .'cookie.txt');
$res_unlock=curl_exec($qc);
$resp=curl_getinfo($qc);
$xml=simplexml_load_string(curl_exec($qc));
if($xml->LockStatus == 'LOCKED_BY_OTHER' || $xml->LockStatus == 'LOCKED_BY_ME')
{
$headers = array(
'Accept: application/xml',
'Content-Type: application/xml',
);
$data= <<<XML
<Entity Type="test">
<Fields>
<Field Name="Name">
<Value>Name of the test</Value>
</Field>
<Field Name="Status">
<Value>Updated Value</Value>
</Field>
</Fields>
</Entity>
XML;
curl_setopt($qc, CURLOPT_URL, $url);
curl_setopt($qc, CURLOPT_HTTPHEADER, $header);
curl_setopt($qc, CURLOPT_HEADER, 1);
curl_setopt($qc, CURLOPT_PUT, 1);
curl_setopt($qc, CURLOPT_CUSTOMREQUEST, "PUT");
curl_setopt($qc, CURLOPT_POSTFIELDS, $data);
curl_setopt($qc, CURLOPT_RETURNTRANSFER, 1);
$result = curl_exec($qc);
$resp=curl_getinfo($qc);
}
else
{
$data='';
curl_setopt($qc, CURLOPT_URL, $url);
curl_setopt($qc, CURLOPT_HEADER, true);
curl_setopt($qc, CURLOPT_POST, 1);
curl_setopt($qc, CURLOPT_POSTFIELDS, $data);
$res_Lock=curl_exec($qc);
$resp=curl_getinfo($qc);
if($resp['http_code'] == 200)
{
$headers = array(
'Accept: application/xml',
'Content-Type: application/xml',
);
$file = BASEPATH."tests.xml";
$data= <<<XML
<Entity Type="test">
<Fields>
<Field Name="Name">
<Value>Name of the test</Value>
</Field>
<Field Name="Status">
<Value>Updated Value</Value>
</Field>
</Fields>
</Entity>
XML;
curl_setopt($qc, CURLOPT_URL, $url);
curl_setopt($qc, CURLOPT_HTTPHEADER, $header);
curl_setopt($qc, CURLOPT_HEADER, 1);
curl_setopt($qc, CURLOPT_PUT, 1);
curl_setopt($qc, CURLOPT_CUSTOMREQUEST, "PUT");
curl_setopt($qc, CURLOPT_POSTFIELDS, $data);
curl_setopt($qc, CURLOPT_RETURNTRANSFER, 1);
$result = curl_exec($qc);
$resp=curl_getinfo($qc);
}
}
}
我得到415 Error
,我无法使用PUT
方法发送数据。
感谢你的帮助。
由于
答案 0 :(得分:0)
在上面,看起来您的HTTP标头位于变量$ headers中,但是您要从$ header设置HTTP标头的curl选项。
我今天在与HP ALM类似的问题上一直在努力。当我100%确定正在设置以下标题时,一切都开始正常工作:
Content-Type:application / xml 接受:application / xml
HP ALM界面似乎有三件事要做:
文档https://almelsevier.saas.hp.com/qcbin/Help/doc_library/api_refs/REST/webframe.html几乎可以通过。
答案 1 :(得分:0)
您应该将CURLOPT_INFILE与PUT操作一起使用。 POSTFIELDS用于POST操作。