Maison > php教程 > php手册 > 【PHP】cURL实现get,post 和 cookie(几个实例)

【PHP】cURL实现get,post 和 cookie(几个实例)

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Libérer: 2016-06-06 19:40:33
original
1210 Les gens l'ont consulté

类于dreamhost这类主机服务商,是显示fopen的使用 的。使用php的curl可以 实现 支持FTP、FTPS、HTTP HTPPS SCP SFTP TFTP TELNET DICT FILE和LDAP。curl 支持SSL证书、HTTP POST、HTTP PUT 、FTP 上传,kerberos、基于HTT式的上传、代理、cookie、用户+口令

类似于dreamhost这类主机服务商,是显示fopen的使用 的。使用php的curl可以实现支持FTP、FTPS、HTTP HTPPS SCP SFTP TFTP TELNET DICT FILE和LDAP。curl 支持SSL证书、HTTP POST、HTTP PUT 、FTP 上传,kerberos、基于HTT格式的上传、代理、cookie、用户+口令证明、文件传送恢复、http代理通道就最常用的来说,是基于http的 get和post方法。

代码实现

1、http的get实现

<?php // 初始化一个 cURL 对象 
$curl = curl_init();
// 设置你需要抓取的URL 
curl_setopt($curl, CURLOPT_URL, 'http://www.baidu.com');
// 设置cURL 参数,要求结果保存到字符串中还是输出到屏幕上。 
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
//不将Header作为数据流输出
curl_setopt($curl, CURLOPT_HEADER, 0);
// 运行cURL,请求网页 
$data = curl_exec($curl);
// 关闭URL请求 
curl_close($curl);
// 显示获得的数据 
var_dump($data); 
?>
Copier après la connexion



2、http的post实现

<?php $url = 'http://www.domain.com/api/' ;
$fields = array(
               'lname'=>'justcoding' ,
               'fname'=>'phplover' ,
               'title'=>'myapi',
               'age'=>'27' ,
               'email'=>'1353777303@gmail.com' ,
               'phone'=>'1353777303'
              );
$post_data = implode('&',$fields);

//open connection
$ch = curl_init() ;
//set the url, number of POST vars, POST data
curl_setopt($ch, CURLOPT_URL,$url) ;
curl_setopt($ch, CURLOPT_POST,1) ; // 启用时会发送一个常规的POST请求,类型为:application/x-www-form-urlencoded,就像表单提交的一样。
curl_setopt($ch, CURLOPT_POSTFIELDS,$post_data); // 在HTTP中的“POST”操作。如果要传送一个文件,需要一个@开头的文件名

ob_start();
curl_exec($ch);
$result = ob_get_contents() ;
ob_end_clean();

echo $result;

//close connection
curl_close($ch) ;
Copier après la connexion

3. php的curl传送cookie

两种方式:

 

一种是自动:

curl_setopt($curlHandle, CURLOPT_COOKIEJAR, 'cookie.txt '); //保存
curl_setopt($curlHandle, CURLOPT_COOKIEFILE, 'cookie.txt '); //读取
Copier après la connexion

这样COOKIE会自动跟上去. 
不过要分两次,一是先访问产生cookie,接着连结才能用cookie

 

例子:

<?php function get_curlcuconent2($filename,$referer)
{
   $cookie_jar = tempnam('./tmp','JSESSIONID');
       
   $ch = curl_init();
   curl_setopt($ch, CURLOPT_URL, $filename);
   curl_setopt($ch, CURLOPT_HEADER, false);
   curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);

   //设置文件读取并提交的cookie路径
   curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie_jar);
   $filecontent=curl_exec($ch);
   curl_close($ch);
       
   $ch = curl_init();
   $hostname ="www.domain.com";
   //$referer="http://www.domain.com/";
   curl_setopt($ch, CURLOPT_URL, $filename);
   curl_setopt($ch, CURLOPT_REFERER, $referer); // 看这里,你也可以说你从google来
   curl_setopt($ch, CURLOPT_USERAGENT, "www.domain.com");

   //$request = "JSESSIONID=abc6szw15ozvZ_PU9b-8r"; //设置POST参数
   //curl_setopt($ch, CURLOPT_POSTFIELDS, $request);   
   // 上面这句,当然你可以说你是baidu,改掉这里的值就ok了,可以<strong>实现小偷的功能,$_SERVER['HTTP_USER_AGENT']
   //你也可以自己做个 spider 了,那么就伪装这里的 CURLOPT_USERAGENT 吧
   //如果你要把这个程序放到linux上用php -q执行那也要写出具体的$_SERVER['HTTP_USER_AGENT'],伪造的也可以
   curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
   curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie_jar);
   curl_setopt($ch, CURLOPT_HEADER, false);//设定是否输出页面内容
   curl_setopt($ch, CURLOPT_GET, 1); // post,get 过去

   $filecontent = curl_exec($ch);
   preg_match_all("/charset=(.+?)[NULL\"\']/is",$filecontent, $charsetarray);
   if(strtolower($charsetarray[1][0])=="utf-8")
         $filecontent=iconv( 'utf-8', 'gb18030//IGNORE' , $filecontent);
   curl_close($ch);
   return $filecontent;
}

?>
Copier après la connexion
一种是自定义:

$header[]= 'Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/x-shockwave-flash, text/html, * '. '/* ';
$header[]= 'Accept-Language: zh-cn ';
$header[]= 'User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 2.0.50727) ';
$header[]= 'Host: '.$你的目标HOST;
$header[]= 'Connection: Keep-Alive ';
$header[]= 'Cookie: '.$你的COOKIE串;

curl_setopt($curlHandel,CURLOPT_HTTPHEADER,$header); 
Copier après la connexion

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Recommandations populaires
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal