cURL通过命令行工作,但不在PHP Curl中工作

时间:2012-07-30 16:47:19

标签: php curl xml-rpc

以下命令在命令行中完美运行:

c:\>curl -v -H "Content-Type: text/xml" -d "<?xml version='1.0' encoding='utf-8'?><methodCall><methodName>create_account</methodName><params><param><value><struct><member><name>user</name><value><string>test</string></value></member><member><name>server</name><value><string>chat3.activengage.com</string></value></member><member><name>password</name><value><string>test</string></value></member></struct></value></param></params></methodCall>" http://localhost:4561
* About to connect() to localhost port 4561 (#0)
*   Trying 127.0.0.1...
* connected
* Connected to localhost (127.0.0.1) port 4561 (#0)
> POST / HTTP/1.1
> User-Agent: curl/7.26.0
> Host: localhost:4561
> Accept: */*
> Content-Type: text/xml
> Content-Length: 428
>
* upload completely sent off: 428 out of 428 bytes
< HTTP/1.1 200 OK
< Content-Length: 113
< Server: Erlang/Process-One
< Connection: close
<
<?xml version="1.0"?><methodResponse><params><param><value><int>0</int></value><
/param></params></methodResponse>* Closing connection #0

在PHP中使用以下代码:

public /*string*/ function registerUser(/*string*/$user,/*string*/$pass){
        $xml = "<?xml version='1.0' encoding='utf-8'?><methodCall><methodName>create_account</methodName><params><param><value><struct><member><name>user</name><value><string>test2</string></value></member><member><name>server</name><value><string>chat3.activengage.com</string></value></member><member><name>password</name><value><string>test</string></value></member></struct></value></param></params></methodCall>";
        $handle = curl_init();
        curl_setopt($handle, CURLOPT_URL, 'http://127.0.0.1:4561');
        curl_setopt($handle, CURLOPT_VERBOSE, 1);
            curl_setopt($handle, CURLOPT_HTTPHEADER, array('Content-Type: text/xml'));
        curl_setopt($handle, CURLOPT_POST, 1);
        curl_setopt($handle, CURLOPT_RETURNTRANSFER, 1);
            curl_setopt($handle, CURLOPT_POSTFIELDS, $xml);
        $content = curl_exec($handle);
        echo $xml;
        $httpCode = curl_getinfo($handle, CURLINFO_HTTP_CODE);
        print_r($httpCode);
        print_r($content);
        if(curl_errno($handle))
        {
         echo 'error:' . curl_error($handle);
        }
        curl_close($handle);
}

结果是HTTP状态代码400.我有什么问题吗?

更新 - CURLINFO_HEADER_OUT的结果

string(99) "POST / HTTP/1.1
Host: localhost:4561
Accept: */*
Content-Type: text/xml
Content-Length: 400

"

1 个答案:

答案 0 :(得分:1)

在我破坏了etc / resolv.conf文件后,从基于浏览器的PHP脚本运行curl请求失败。

我在访问后发现了这个

php5-curl error: couldn't resolve host

修复resolve.conf文件后,如下所示: (注意:192.168.1.1是我的路由器地址)

# Generated by NetworkManager
nameserver 192.168.1.1

Curl表现得符合预期。

我希望它可以帮到你