php使用curl访问https示例分享


Posted in PHP onJanuary 17, 2014

为方便说明,先上代码吧

/** 
 * curl POST 
 * 
 * @param   string  url 
 * @param   array   数据 
 * @param   int     请求超时时间 
 * @param   bool    HTTPS时是否进行严格认证 
 * @return  string 
 */  
function curlPost($url, $data = array(), $timeout = 30, $CA = true){        $cacert = getcwd() . '/cacert.pem'; //CA根证书  
    $SSL = substr($url, 0, 8) == "https://" ? true : false;  
    $ch = curl_init();  
    curl_setopt($ch, CURLOPT_URL, $url);  
    curl_setopt($ch, CURLOPT_TIMEOUT, $timeout);  
    curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, $timeout-2);  
    if ($SSL && $CA) {  
        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, true);   // 只信任CA颁布的证书  
        curl_setopt($ch, CURLOPT_CAINFO, $cacert); // CA根证书(用来验证的网站证书是否是CA颁布)  
        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 2); // 检查证书中是否设置域名,并且是否与提供的主机名匹配  
    } else if ($SSL && !$CA) {  
        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); // 信任任何证书  
        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 1); // 检查证书中是否设置域名  
    }  
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);  
    curl_setopt($ch, CURLOPT_HTTPHEADER, array('Expect:')); //避免data数据过长问题  
    curl_setopt($ch, CURLOPT_POST, true);  
    curl_setopt($ch, CURLOPT_POSTFIELDS, $data);  
    //curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($data)); //data with URLEncode  
    $ret = curl_exec($ch);  
    //var_dump(curl_error($ch));  //查看报错信息  
    curl_close($ch);  
    return $ret;    
}   

如果URL地址是https打头,那就走SSL,否则就走普通的HTTP协议。

是否走HTTPS的话就安全了吗?其实SSL也有不同的验证程度。

例如需不需要验证证书中的公用名呢?(BTW:公用名(Common Name)一般来讲就是填写你将要申请SSL证书的域名 (domain)或子域名(sub domain)。)

需要验证主机名吗?

是任何证书都信任呢还是只信任CA颁布的呢?

(我擦嘞,电池快没点了,只捡关键地儿说了 - -|||)

如果网站SSL证书买的是CA的(通常比较贵),那么访问时可以使用比较严格的认证,即:

curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, true);   // 只信任CA颁布的证书 
curl_setopt($ch, CURLOPT_CAINFO, $cacert); // CA根证书(用来验证的网站证书是否是CA颁布) 
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 2); // 检查证书中是否设置域名,并且是否与提供的主机名匹配

如果网站的证书是自己生成的,或者是网上的小机构申请的,那么访问时如果使用严格认证则不会通过,直接返回false。(对了,返回false时可以打印curl_error($ch)查看具体错误信息。)此时可以根据情况通过降低验证程度来保证正常访问,例如:

curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); // 信任任何证书 
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 1); // 检查证书中是否设置域名(为0也可以,就是连域名存在与否都不验证了)

平时我们使用浏览器访问各个https网站时,有时会遇到证书不受信的提示,其实就是因为这些网站的证书不是正规CA机构颁布的。

市面上各种浏览器中都内置了CA根证书列表信息,访问有CA颁布证书的网站时,会根据根证书验证这些网站的证书,所以就不会有这个提示了。

关于CA根证书文件,其实就是包含了各个主要CA机构的公钥证书,用来验证网站的证书是否是这些机构颁发的。

这里的这个文件是来源于mozilla的源码树,又转换成PEM格式证书文件。(大家可以到这里下载现成的http://curl.haxx.se/ca/cacert.pem)

最后说一个和SSL无关的东西:

curl_setopt($ch, CURLOPT_HTTPHEADER, array('Expect:'));

这个主要是为了解决POST时数据过长问题

PHP 相关文章推荐
PHP 如何向 MySQL 发送数据
Oct 09 PHP
常用表单验证类,有了这个,一般的验证就都齐了。
Dec 06 PHP
php a simple smtp class
Nov 26 PHP
攻克CakePHP系列三 表单数据增删改
Oct 22 PHP
PHP n个不重复的随机数生成代码
Jun 23 PHP
php中用foreach来操作数组的代码
Jul 17 PHP
利用Ffmpeg获得flv视频缩略图和视频时间的代码
Sep 15 PHP
深入Memcache的Session数据的多服务器共享详解
Jun 13 PHP
MongoDB在PHP中的常用操作小结
Feb 20 PHP
php匹配字符中链接地址的方法
Dec 22 PHP
PHP curl 或 file_get_contents 获取需要授权页面的方法
May 05 PHP
老生常谈php中传统验证与thinkphp框架(必看篇)
Jun 10 PHP
php将url地址转化为完整的a标签链接代码(php为url地址添加a标签)
Jan 17 #PHP
php 检查电子邮件函数(自写)
Jan 16 #PHP
php mail to 配置详解
Jan 16 #PHP
php生成txt文件标题及内容的方法
Jan 16 #PHP
PHP获取php,mysql,apche的版本信息示例代码
Jan 16 #PHP
php获取淘宝分类id示例
Jan 16 #PHP
php生成数组的使用示例 php全组合算法
Jan 16 #PHP
You might like
PHP将整个网站生成HTML纯静态网页的方法总结
2012/02/05 PHP
解析PHP工厂模式的好处
2013/06/18 PHP
php json与xml序列化/反序列化
2013/10/28 PHP
PHP实现把文本中的URL转换为链接的auolink()函数分享
2014/07/29 PHP
laravel5.4利用163邮箱发送邮件的步骤详解
2017/09/22 PHP
php实现微信支付之企业付款
2018/05/30 PHP
JavaScript Event学习第十章 一些可替换的事件对
2010/02/10 Javascript
javascript delete 使用示例代码
2010/03/29 Javascript
js 兼容多浏览器的回车和鼠标焦点事件代码(IE6/7/8,firefox,chrome)
2010/04/14 Javascript
技术男用来对妹子表白的百度首页
2014/07/23 Javascript
JavaScript实现找出数组中最长的连续数字序列
2014/09/03 Javascript
jQuery异步上传文件插件ajaxFileUpload详细介绍
2015/05/19 Javascript
实例讲解jQuery中对事件的命名空间的运用
2016/05/24 Javascript
jQuery中deferred对象使用方法详解
2016/07/14 Javascript
jQuery实现鼠标经过像翻页和描点链接效果
2016/08/08 Javascript
使用contextMenu插件实现Bootstrap table弹出右键菜单
2017/02/20 Javascript
angular+bootstrap的双向数据绑定实例
2017/03/03 Javascript
jQuery插件FusionCharts绘制的2D条状图效果【附demo源码】
2017/05/13 jQuery
Web开发使用Angular实现用户密码强度判别的方法
2017/09/27 Javascript
Vue引用Swiper4插件无法重写分页器样式的解决方法
2018/09/27 Javascript
Vue常用的几个指令附完整案例
2018/11/06 Javascript
JS实现星星海特效
2019/12/24 Javascript
JavaScript遍历数组的方法代码实例
2020/01/14 Javascript
详解JavaScript之Array.reduce源码解读
2020/11/01 Javascript
python函数装饰器用法实例详解
2015/06/04 Python
python开发之for循环操作实例详解
2015/11/12 Python
Python字符串、整数、和浮点型数相互转换实例
2018/08/04 Python
使用python将mysql数据库的数据转换为json数据的方法
2019/07/01 Python
墨西哥皇宫度假村预订:Palace Resorts
2018/06/16 全球购物
市场部专员岗位职责
2013/11/30 职场文书
社会保险接收函
2014/01/12 职场文书
护理专科自荐书范文
2014/02/18 职场文书
年级组长自我鉴定
2014/02/22 职场文书
校长师德师风自我剖析材料
2014/09/29 职场文书
募捐感谢信
2015/01/22 职场文书
2016年端午节校园广播稿
2015/12/18 职场文书