php中CURL的一些参数解释

<?php
/************访问的url*************/
curl_setopt($ch, CURLOPT_URL, $curl);//设置访问的URL

/************输出信息的设置*************/
curl_setopt($ch, CURLOPT_HEADER, 0);	//为0时,输出中不包含相应头信息
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);//为1时,返回的信息不直接输出

/************post*************/
curl_setopt($ch, CURLOPT_POST, 1);		//是post请求,就设置为1
curl_setopt($ch, CURLOPT_POSTFIELDS, $post_fields);	//$post_fields可以是数组也可以是url里面?后面的那个参数串
curl_setopt($curlobj, CURLOPT_HTTPHEADER, array("application/x-www-form-urlencoded; charset=utf-8", 
	"Content-length: ".strlen($data)
	)); //纯post请求的话这个不一定要
/*
网友案例
为了安全,我们的web服务主机往往不能上网。维护的时候,也是通过跳板机,ssh登录后去操作。

有时候我们的程序需要访问外网。比如需要调用外网其他程序的某个接口。这下该怎么办呢?

我们可以通过PHP的CURL函数的CURLOPT_HTTPHEADER来配置设置host访问。

在开发中,我遇到这样一个例子。
有一个活动程序,需要调用qzone那边的一个接口。

如下代码示例:

$host = array("Host: act.qzone.qq.com");
$data = 'user=xxx&qq=xxx&id=xxx&post=xxx';
$url = 'http://192.168.1.12/xxx/xxx/api/';
var_dump( $this->curl_post($host, $data,$url) );


* 提交请求
* @param $host array 需要配置的域名 array("Host: act.qzone.qq.com");
* @param $data string 需要提交的数据 'user=xxx&qq=xxx&id=xxx&post=xxx'....
* @param $url string 要提交的url 'http://192.168.1.12/xxx/xxx/api/';
*
	function curl_post($host,$data,$url)
    {
       $ch = curl_init();
       $res= curl_setopt ($ch, CURLOPT_URL,$url);
       var_dump($res);
       curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
       curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
       curl_setopt ($ch, CURLOPT_HEADER, 0);
       curl_setopt($ch, CURLOPT_POST, 1);
       curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
       curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1);
       curl_setopt($ch,CURLOPT_HTTPHEADER,$host);
       $result = curl_exec ($ch);
       curl_close($ch);
       if ($result == NULL) {
           return 0;
       }
       TMDebugUtils::debugLog($result);
       return $result;
    }
通过PHP CURL CURLOPT_HTTPHEADER设置HOST很方便的解决了访问外网接口的问题。
*/
	

/************cookie*************/
下面这两个可以不用,cookie会保存到默认路径
curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie_file);	//保存cookie的文件地址,这个必须是文件的完整路径,相对路径没用
curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie_file); //从文件中获取cookie信息


//CURLOPT_COOKIESESSION启用时curl会仅仅传递一个session cookie,忽略其他的cookie,默认状况下cURL会将所有的cookie返回给服务端。
curl_setopt($curlobj, CURLOPT_COOKIESESSION, TRUE);  


/************页面跳转*************/
curl_setopt($curlobj, CURLOPT_FOLLOWLOCATION, 1); // 这样能够让cURL支持页面链接跳转

/************超时*************/
curl_setopt($curlobj, CURLOPT_TIMEOUT, 300); // 设置超时时间

/************FTP之下载*************/

curl_setopt($curlobj, CURLOPT_USERPWD, "FTP用户名:密码");//FTP用户名:密码
curl_setopt($curlobj, CURLOPT_FILE, $outfile);		//fopen提供wb模式打开的本地文件指针
$rtn = curl_exec($curlobj);  
fclose($outfile); 

/************FTP之上传*************/
curl_setopt($curlobj, CURLOPT_USERPWD, "FTP用户名:密码");//FTP用户名:密码
curl_setopt($curlobj, CURLOPT_UPLOAD, 1);
curl_setopt($curlobj, CURLOPT_INFILE, $fp);		//打开的本地文件指针
curl_setopt($curlobj, CURLOPT_INFILESIZE, filesize($localfile));	//文件路径


/************https*************/
①做验证的时候
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, true);//SSL证书认证  verifypeer
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 2);//严格认证
curl_setopt($curl, CURLOPT_CAINFO,$cacert_url);//证书地址  getcwd().'\\cacert.pem';
/*
网友解释

CURLOPT_SSL_VERIFYHOST的值

设为0表示不检查证书
设为1表示检查证书中是否有CN(common name)字段
设为2表示在1的基础上校验当前的域名是否与CN匹配
而libcurl早期版本中这个变量是boolean值,为true时作用同目前设置为2,后来出于调试需求,增加了仅校验是否有CN字段的选项,因此两个值true/false就不够用了,升级为0/1/2三个值。

再后来(libcurl_7.28.1之后的版本),这个调试选项由于经常被开发者用错,被去掉了,因此目前也不支持1了,只有0/2两种取值。

引自 libcurl API

When the verify value is 1, curl_easy_setopt will return an error and
the option value will not be changed. It was previously (in 7.28.0 and
earlier) a debug option of some sorts, but it is no longer supported
due to frequently leading to programmer mistakes. Future versions will
stop returning an error for 1 and just treat 1 and 2 the same.

最新版本,它的默认值就是2,因此,这行代码,可以省略不写。
*/
②不做验证
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);//不做服务器认证
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);//不做客户端认证


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值