类似于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实现
复制代码 代码如下:
$ch = curl_init("http://www.domain.com/api/index.php?test=1") ; 
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true) ; // 获取数据返回 
curl_setopt($ch, CURLOPT_BINARYTRANSFER, true) ; // 在启用 CURLOPT_RETURNTRANSFER 时候将获取数据返回 
echo $output = curl_exec($ch) ; 

/* 写入文件 */ 
$fh = fopen("out.html", 'w') ; 
fwrite($fh, $output) ; 
fclose($fh) ;  

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); 

注意:post请求的参数要用get方式那样连接起来,作为字符串传递:
如:$params = 'userId='.$this->user_id.'&auth='.$this->auth.'&sig='.$this->sig

还有跨平台的请求,curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); // 使用自动跳转 (很重要)

//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,count($fields)) ; // 启用时会发送一个常规的POST请求,类型为:application/x-www-form-urlencoded,就像表单提交的一样。 
curl_setopt($ch, CURLOPT_POSTFIELDS,$fields); // 在HTTP中的“POST”操作。如果要传送一个文件,需要一个@开头的文件名 

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

echo $result; 

//close connection 
curl_close($ch) ; 

复制代码 代码如下:
<?php 

if($_GET['test']) 

     print_r($_GET); 


if($_POST) 

    print_r($_POST); 
}  

php的curl传送cookie
 
两种方式:
一种是自动:
复制代码 代码如下:
curl_setopt($curlHandle, CURLOPT_COOKIEJAR, 'cookie.txt '); //保存 
curl_setopt($curlHandle, CURLOPT_COOKIEFILE, 'cookie.txt '); //读取 

这样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了,可以实现小偷的功能,$_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; 


?> 

一种自定义:
复制代码 代码如下:
$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); 

广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!

稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!

昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。

这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。

而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?