PHP 使用 cURL HTTPS 协议证书认证问题

参考 :

CA证书下载地址 :

PHP 使用 cURL 模块访问 https 时认证问题

$ch = curl_init();
$options = array(
    CURLOPT_URL=>$url,
    // 返回状态大于400时报错错误, 默认忽略
    CURLOPT_FAILONERROR=>true, 
    // 将返回内容赋值到变量, 默认直接输出
    CURLOPT_RETURNTRANSFER=>false,
    // 汇报全部的连接过程和意外
    CURLOPT_VERBOSE => 1,
    /*
    将verbose存储在资源中
    curl_setopt($ch, CURLOPT_STDERR, fopen(log.log, a+));
    OR 
    curl_setopt($session, CURLOPT_FILE, $logfh);
    */
    //显示头部信息
    // CURLOPT_HEADER => TRUE,
    CURLOPT_SSLVERSION => 3,
    
    // **关键部分** 
    // 这里的路径指向认证服务器证书的CA证书, 不是服务器的证书
    CURLOPT_CAINFO=>A:xxxcertcacert.pem,
    //CURLOPT_CAPATH=>dirname(__FILE__),
    
    // 连接时使用 SSL/TLS 认证 , 一般和下面的 CURLOPT_SSL_VERIFYHOST 一起用
    // 忽略SSL/TLS认证, 2者同时为假
    CURLOPT_SSL_VERIFYPEER=>TRUE,
    // 认证证书中公用名称, 一般指证书中的 Common Name 即域名
    CURLOPT_SSL_VERIFYHOST=>2,
    
    //CURLOPT_HTTP200ALIASES=>[200],
    // 设置代理
    //CURLOPT_PROXY=>http://127.0.0.1:8989,
    CURLOPT_POST=>true,
    // POST 内容, 需要urlencode处理一下
    CURLOPT_POSTFIELDS=>$data,
    // 设置头部
    CURLOPT_HTTPHEADER=>$header,
);
curl_setopt_array($ch, $options);
        
try{
    $reponse = curl_exec($ch);
    if($reponse === false){
        throw new Exception("访问异常: " . curl_error($ch), 400);
    }
}catch(Exception $e){
    echo $e->getMessage();
}
//echo $reponse;
// print_r(curl_getinfo($ch));
curl_close($ch);
参考 : CA证书下载地址 : PHP 使用 cURL 模块访问 https 时认证问题 $ch = curl_init(); $options = array( CURLOPT_URL=>$url, // 返回状态大于400时报错错误, 默认忽略 CURLOPT_FAILONERROR=>true, // 将返回内容赋值到变量, 默认直接输出 CURLOPT_RETURNTRANSFER=>false, // 汇报全部的连接过程和意外 CURLOPT_VERBOSE => 1, /* 将verbose存储在资源中 curl_setopt($ch, CURLOPT_STDERR, fopen(log.log, a+)); OR curl_setopt($session, CURLOPT_FILE, $logfh); */ //显示头部信息 // CURLOPT_HEADER => TRUE, CURLOPT_SSLVERSION => 3, // **关键部分** // 这里的路径指向认证服务器证书的CA证书, 不是服务器的证书 CURLOPT_CAINFO=>A:xxxcertcacert.pem, //CURLOPT_CAPATH=>dirname(__FILE__), // 连接时使用 SSL/TLS 认证 , 一般和下面的 CURLOPT_SSL_VERIFYHOST 一起用 // 忽略SSL/TLS认证, 2者同时为假 CURLOPT_SSL_VERIFYPEER=>TRUE, // 认证证书中公用名称, 一般指证书中的 Common Name 即域名 CURLOPT_SSL_VERIFYHOST=>2, //CURLOPT_HTTP200ALIASES=>[200], // 设置代理 //CURLOPT_PROXY=>http://127.0.0.1:8989, CURLOPT_POST=>true, // POST 内容, 需要urlencode处理一下 CURLOPT_POSTFIELDS=>$data, // 设置头部 CURLOPT_HTTPHEADER=>$header, ); curl_setopt_array($ch, $options); try{ $reponse = curl_exec($ch); if($reponse === false){ throw new Exception("访问异常: " . curl_error($ch), 400); } }catch(Exception $e){ echo $e->getMessage(); } //echo $reponse; // print_r(curl_getinfo($ch)); curl_close($ch);
经验分享 程序员 微信小程序 职场和发展