CURL - HTTPS Wierd error

Posted by Vincent on Stack Overflow See other posts from Stack Overflow or by Vincent
Published on 2010-04-28T22:27:54Z Indexed on 2010/04/28 22:47 UTC
Read the original article Hit count: 489

Filed under:
|
|
|

All,

I am having trouble requesting info from HTTPS site using CURL and PHP. I am using Solaris 10. It so happens that sometimes it works and sometimes it doesn't. I am not sure what is the cause. If it doesn't work, this is the entry recorded in the verbose log:

* About to connect() to 10.10.101.12 port 443 (#0)
*   Trying 10.10.101.12... * connected
* Connected to 10.10.101.12 (10.10.101.12) port 443 (#0)
* error setting certificate verify locations, continuing anyway:
*   CAfile: /etc/opt/webstack/curl/curlCA
  CApath: none
* error:80089077:lib(128):func(137):reason(119)
* Closing connection #0

If it works, this is the entry recorded in the verbose log:

* About to connect() to 10.10.101.12 port 443 (#0)
*   Trying 10.10.101.12... * connected
* Connected to 10.10.101.12 (10.10.101.12) port 443 (#0)
* error setting certificate verify locations, continuing anyway:
*   CAfile: /etc/opt/webstack/curl/curlCA
  CApath: none
* SSL connection using DHE-RSA-AES256-SHA
* Server certificate:
*        subject: C=CA, ST=British Columnbia, L=Vancouver, O=google, OU=FDN, CN=g.googlenet.com, [email protected]
*        start date: 2007-07-24 23:06:32 GMT
*        expire date: 2027-09-07 23:06:32 GMT
*        issuer: C=US, ST=California, L=Sunnyvale, O=Google, OU=Certificate Authority, CN=support, [email protected]
*        SSL certificate verify result: unable to get local issuer certificate (20), continuing anyway.
> POST /gportal/gpmgr HTTP/1.1^M
Host: 10.10.101.12^M
Accept: */*^M
Accept-Encoding: gzip,deflate^M
Content-Length: 1623^M
Content-Type: application/x-www-form-urlencoded^M
Expect: 100-continue^M
^M
< HTTP/1.1 100 Continue^M
< HTTP/1.1 200 OK^M
< Date: Wed, 28 Apr 2010 21:56:15 GMT^M
< Server: Apache^M
< Cache-Control: no-cache^M
< Pragma: no-cache^M
< Vary: Accept-Encoding^M
< Content-Encoding: gzip^M
< Content-Length: 1453^M
< Content-Type: application/json^M
< ^M
* Connection #0 to host 10.10.101.12 left intact
* Closing connection #0

My CURL options are as under:

    $ch = curl_init();

    $devnull = fopen('/tmp/curlcookie.txt', 'w');
    $fp_err = fopen('/tmp/verbose_file.txt', 'ab+');
    fwrite($fp_err, date('Y-m-d H:i:s')."\n\n");

    curl_setopt($ch, CURLOPT_STDERR, $devnull);
    curl_setopt($ch, CURLOPT_POST, 1);
    curl_setopt($ch, CURLOPT_URL, $desturl);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
    curl_setopt($ch, CURLOPT_HEADER, false);
    curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 0);
    curl_setopt($ch, CURLOPT_CONNECTTIMEOUT,120);
    curl_setopt($ch, CURLOPT_AUTOREFERER, true);
    curl_setopt($ch, CURLOPT_ENCODING, 'gzip,deflate');
    curl_setopt($ch, CURLOPT_POSTFIELDS, $postdata);
    curl_setopt($ch, CURLOPT_VERBOSE,1);
    curl_setopt($ch, CURLOPT_FAILONERROR, true);
    curl_setopt($ch, CURLOPT_STDERR, $fp_err);

    $ret = curl_exec($ch);

Anybody has any idea, why it works sometimes but fails mostly?

Thanks

© Stack Overflow or respective owner

Related posts about php5

Related posts about solaris