• php使用curl库进行ssl双向认证


    官方文档:

    http://www.php.net/manual/zh/function.curl-setopt.php#10692

    官方举例:

    <?php
    curl_setopt
    ($chCURLOPT_VERBOSE'1');
    curl_setopt($chCURLOPT_SSL_VERIFYHOST'1');
    curl_setopt($chCURLOPT_SSL_VERIFYPEER'1');
    curl_setopt($chCURLOPT_CAINFO,  getcwd().'/cert/ca.crt');
    curl_setopt($chCURLOPT_SSLCERTgetcwd().'/cert/mycert.pem');
    curl_setopt($chCURLOPT_SSLCERTPASSWD'password');
    ?>

    由于业务原因,后台登陆需要使用SSL双向认证,即web服务器有证书,浏览器客户端也需要安装证书

    然后这样的话,php接口文件就需要走443端口来访问了

    直接附上代码:

            /**
             * @name ssl Curl Post数据
             * @param string $url 接收数据的api
             * @param string $vars 提交的数据
             * @param int $second 要求程序必须在$second秒内完成,负责到$second秒后放到后台执行
             * @return string or boolean 成功且对方有返回值则返回
             */
            function curl_post_ssl($url, $vars, $second=30,$aHeader=array())
            {
                            $ch = curl_init();
                            //curl_setopt($ch,CURLOPT_VERBOSE,'1');
                            curl_setopt($ch,CURLOPT_TIMEOUT,$second);
                            curl_setopt($ch,CURLOPT_RETURNTRANSFER, 1);
                            curl_setopt($ch,CURLOPT_URL,$url);
                            curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false);
                            curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,false);
                            curl_setopt($ch,CURLOPT_SSLCERTTYPE,'PEM');
                            curl_setopt($ch,CURLOPT_SSLCERT,'/data/cert/php.pem');
                            curl_setopt($ch,CURLOPT_SSLCERTPASSWD,'1234');
                            curl_setopt($ch,CURLOPT_SSLKEYTYPE,'PEM');
                            curl_setopt($ch,CURLOPT_SSLKEY,'/data/cert/php_private.pem');
    
                            if( count($aHeader) >= 1 ){
                                    curl_setopt($ch, CURLOPT_HTTPHEADER, $aHeader);
                            }
    
                            curl_setopt($ch,CURLOPT_POST, 1);
                            curl_setopt($ch,CURLOPT_POSTFIELDS,$vars);
                            $data = curl_exec($ch);
                            curl_close($ch);
                            if($data)
                                    return $data;
                            else    
                                    return false;
            }

    参数解释:

    CURLOPT_TIMEOUT:超时时间

    CURLOPT_RETURNTRANSFER:是否要求返回数据

    CURLOPT_SSL_VERIFYPEER:是否检测服务器的证书是否由正规浏览器认证过的授权CA颁发的

    CURLOPT_SSL_VERIFYHOST:是否检测服务器的域名与证书上的是否一致

    CURLOPT_SSLCERTTYPE:证书类型,"PEM" (default), "DER", and"ENG".

    CURLOPT_SSLCERT:证书存放路径

    CURLOPT_SSLCERTPASSWD:证书密码

    CURLOPT_SSLKEYTYPE:私钥类型,"PEM" (default), "DER", and"ENG".

    CURLOPT_SSLKEY:私钥存放路径

    由于php的curl只支持pem格式der、eng格式,而之前生成的是p12的格式,所以需要转换一下

    PKCS#12 到 PEM 的转换

    openssl pkcs12 -nocerts -nodes -in cert.p12 -out private.pem
    验证 
    openssl pkcs12 -clcerts -nokeys -in cert.p12 -out cert.pem
  • 相关阅读:
    自动化测试之读取配置文件 | 踩坑指南
    文未有福利 | BAT 名企大厂做接口自动化如何高效使用 Requests ?
    高效能 Tester 必会的 Python 测试框架技巧
    移动自动化测试从入门到高级实战
    1 天,1000+ 测试工程师分享了这个课程 | 年度福利
    H5性能分析实战来啦~
    接口测试实战 | Android 高版本无法抓取 HTTPS,怎么办?
    实战 | 接口自动化测试框架开发(Pytest+Allure+AIOHTTP+用例自动生成)
    第一期线上沙龙PPT领取方式
    Java日志第48天 2020.8.24
  • 原文地址:https://www.cnblogs.com/freespider/p/3622830.html
Copyright © 2020-2023  润新知