>  기사  >  백엔드 개발  >  PHP에서 CURL을 사용하는 PHP 컬의 자세한 분석 및 일반적인 함정

PHP에서 CURL을 사용하는 PHP 컬의 자세한 분석 및 일반적인 함정

不言
不言원래의
2018-04-18 16:09:3764453검색

이 기사에서는 주로 PHP에서 CURL을 사용하여 PHP 컬의 자세한 분석과 일반적인 함정을 소개합니다. 이제 이를 공유하고 참고할 수 있습니다. 편집자를 따라가서 구경해 보세요

중국의 발렌타인데이입니다. 같이 놀 수 있는 여자가 없다면, 여자에게 놀릴 수 있는 동급생이 있으면 서버를 "놀리세요". 그녀를 왼쪽으로 안고 오른쪽으로 서버를 안아줍니다. 게다가 소녀는 선물을 원합니다. 예, 서버는 사용되지 않습니다. 자, 간단히 말해서 오늘의 도구인 CURL(클라이언트 URL 라이브러리)을 소개하겠습니다. 물론 오늘은 이 도구를 PHP에서 사용할 것입니다.

0. 컬이란 무엇입니까?

PHP는 현재 http, https를 지원하는 다양한 유형의 프로토콜을 사용하여 다양한 유형의 서버에 연결하고 통신할 수 있도록 해주는 Daniel Stenberg가 만든 라이브러리인 libcurl을 지원합니다. , ftp, gopher, telnet, dict, file 및 ldap 프로토콜. libcurl은 또한 HTTPS 인증서, HTTP POST, HTTP PUT, FTP 업로드(PHP의 ftp 확장으로도 수행 가능), HTTP 양식 기반 업로드, 프록시, 쿠키를 지원합니다. 및 사용자+비밀번호 인증.

PHP의 컬에 대한 설명입니다. 간단히 말해서, 컬은 URL을 통해 다양한 유형의 서버와 연결하고, 채팅하고, 심층적으로 통신할 수 있는 라이브러리입니다. 많은 계약을 지원합니다. 그리고 사람들은 컬이 https 인증, http 포스트, ftp 업로드, 프록시, 쿠키, 단순 비밀번호 인증 및 기타 기능을 지원할 수 있다고 말했습니다.

말을 너무 많이 해서 실제로는 별로 실감이 나지 않습니다. 처음에는 연락을 시작하기 전에 서버 측에서 다른 서버에 POST 요청을 시작해야 했습니다. 컬을 사용해서 느꼈어요.

공식적으로 사용 방법에 대해 이야기하기 전에 먼저 PHP 환경에 컬 모듈을 설치하고 활성화해야 한다는 점을 언급하겠습니다. 특정 방법은 시스템마다 다르므로 확인하실 수 있습니다. Google에서 확인하거나 공식 PHP 문서는 매우 간단합니다.

1. 먼저 사용해 보세요

도구를 받은 후 먼저 가지고 놀면서 편한지 확인해야 합니다. 그렇지 않으면 받자마자 사용하면 어떻게 엉망이 될까요? 자신의 코드를 작성하고 서버를 엉망으로 만들까요?

예를 들어, 유명한 "네트워크 연결 테스트" 웹사이트인 Baidu를 예로 들어, 컬

<?php 
    // create curl resource 
   $ch = curl_init(); 

   // set url 
   curl_setopt($ch, CURLOPT_URL, "baidu.com"); 

   //return the transfer as a string 
   curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 

   // $output contains the output string 
   $output = curl_exec($ch); 

    //echo output
    echo $output;

   // close curl resource to free up system resources 
   curl_close($ch);      
?>

이 PHP 파일을 로컬 환경 브라우저에서 열면 나타나는 페이지는 Baidu의 홈페이지입니다. 방금 입력한 "localhost"는 무엇입니까?

위의 코드와 주석은 이 코드가 수행하는 작업을 완전히 설명했습니다.

$ch = cur_init(), 컬 세션 리소스를 생성하고 성공적으로 핸들을 반환합니다. $ch = curl_init(),创建了一个curl会话资源,成功返回一个句柄;  
curl_setopt($ch, CURLOPT_URL, "baidu.com"),设置URL,不用说;

上面两句可以合起来变一句$ch = curl_init("baidu.com")

curl_setopt($ch, CURLOPT_RETURNTRANSFER, 0)这是设置是否将响应结果存入变量,1是存入,0是直接echo出;

$output = curl_exec($ch)执行,然后将响应结果存入$output变量,供下面echo;

curl_close($ch)关闭这个curl会话资源。

PHP中使用curl大致就是这么一个形式,其中第二步,通过curl_setoptcurl_setopt($ch, CURLOPT_URL, "baidu.com"), 불필요 즉, URL을 설정하세요.

위 두 문장을 하나의 문장으로 결합할 수 있습니다. $ch = cur_init("baidu.com")

curl_setopt($ch, CURLOPT_RETURNTRANSFER, 0)응답 결과를 변수에 저장할지 여부를 설정하는 것으로, 1은 저장, 0은 직접 에코 출력을 의미합니다. <p></p> <code>$output =cur_exec($ch); > 다음 echo에 대한 $output 변수를 실행하고 저장합니다.

curl_close($ch)이 컬 세션 리소스를 닫습니다.

PHP에서 컬을 사용하는 방법은 대략 이런 형태입니다. 그 중 두 번째 단계는 curl_setopt 메소드를 통해 매개변수를 설정하는 것입니다. 관심 있는 분은 읽어보시면 됩니다. 매개변수 설정에 대한 공식 기사입니다. 매개변수에 대한 자세한 참조는 토하고 싶게 만들지만, 필요에 따라 연습하면 완벽해집니다.

요약하자면, PHP에서 컬의 사용법은 다음과 같습니다: 컬 세션 생성 -> 구성 매개변수 ->

몇 가지 일반적인 시나리오를 살펴보고 올바르게 "여자를 선택"(올바르게 서버를 선택)하기 위해 "옷을 입는" 방법(구성 매개변수)을 살펴보겠습니다.

2. 인사하기 - GET 및 POST 요청과 HTTPS 프로토콜 처리



먼저 서버에 인사하고 서버에 Hello를 보낸 후 서버가 어떻게 응답하는지 확인하는 것이 가장 편리한 방법입니다. 물론 POST와 같은 작은 메모도 괜찮습니다.

2.1 GET 요청

"유명 게이 데이팅 사이트 github에서 키워드 검색하기"를 예로 들어보겠습니다

//通过curl进行GET请求的案例
<?php 
    // create curl resource 
   $ch = curl_init(); 

   // set url 
   curl_setopt($ch, CURLOPT_URL, "https://github.com/search?q=react"); 

   //return the transfer as a string 
   curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 

   // $output contains the output string 
   $output = curl_exec($ch); 

   //echo output
   echo $output;

   // close curl resource to free up system resources 
   curl_close($ch);      
?>
앞의 예와 별반 차이가 없는 것 같지만, 언급할 수 있는 두 가지 사항은 다음과 같습니다.
1. 기본 요청 방법은 GET이므로 GET 방법을 명시적으로 지정할 필요가 없습니다.

2.

https🎜 요청, http가 아닌 요청, 일부 사람들은 HTTPS 요청에 몇 가지를 추가해야 하는 것을 여러 곳에서 보았을 수 있습니다. SSL 인증서 검사 등을 우회하는 코드 라인. 리소스가 성공적으로 요청되었지만 여기서는 필요하지 않은 것 같습니다. 이유는 무엇입니까? 🎜🎜🎜두 가지 Curl 옵션은 다음과 같이 정의됩니다. 🎜🎜
CURLOPT_SSL_VERIFYPEER - verify the peer's SSL certificate  
CURLOPT_SSL_VERIFYHOST - verify the certificate's name against host
🎜🎜 둘 다 Curl에서 기본적으로 true로 설정되어 있으며 합당한 이유가 없는 한 비활성화하면 안 됩니다. 일반적으로 메시지를 보내는 경우에만 필요합니다. 일반적으로 개발 중에만 발생하는 문제인 유효하지 않거나 자체 서명된 인증서가 있는 서버에 대한 요청. 모든 공개 사이트는 유효한 인증서를 제공해야 하며 이러한 옵션을 비활성화하면 잠재적으로 보안 문제가 발생할 수 있습니다.🎜

即,除非用了非法或者自制的证书,这大多数出现在开发环境中,你才将这两行设置为false以避开ssl证书检查,否者不需要这么做,这么做是不安全的做法。

2.2 POST请求

那如何进行POST请求呢?为了测试,先在某个测试服务器传了一个接收POST的脚本:

//testRespond.php
<?php  
    $phpInput=file_get_contents(&#39;php://input&#39;);
    echo urldecode($phpInput);
?>

发送普通数据

然后在本地写一个请求:

<?php 
    $data=array(
    "name" => "Lei",
    "msg" => "Are you OK?"
    );

    $ch = curl_init(); 

    curl_setopt($ch, CURLOPT_URL, "http://测试服务器的IP马赛克/testRespond.php"); 
    curl_setopt($ch, CURLOPT_POST, 1);
    //The number of seconds to wait while trying to connect. Use 0 to wait indefinitely.
    curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 60); 
    curl_setopt($ch, CURLOPT_POSTFIELDS , http_build_query($data));
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 

    $output = curl_exec($ch); 

    echo $output;

    curl_close($ch);      
?>

浏览器运行结果是:

name=Lei&msg=Are you OK?

这里我们是构造了一个数组作为POST数据传给服务器:

  • curl_setopt($ch, CURLOPT_POST, 1)表明是POST请求;

  • curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 60)设置一个最长的可忍受的连接时间,秒为单位,总不能一直等下去变成木乃伊吧;

  • curl_setopt($ch, CURLOPT_POSTFIELDS , http_build_query($data))设置POST的数据域,因为这里是数组数据形式的(等会来讲json格式),所以用http_build_query处理一下。

对于json数据呢,又怎么进行POST请求呢?

<?php 
    $data=&#39;{"name":"Lei","msg":"Are you OK?"}&#39;;

    $ch = curl_init(); 

    curl_setopt($ch, CURLOPT_URL, "http://测试服务器的IP马赛克/testRespond.php"); 
    curl_setopt($ch, CURLOPT_POST, 1);
    curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 60); 
    curl_setopt($ch, CURLOPT_HTTPHEADER, array(&#39;Content-Type: application/json&#39;, &#39;Content-Length:&#39; . strlen($data)));
    curl_setopt($ch, CURLOPT_POSTFIELDS , $data);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 

    $output = curl_exec($ch); 

    echo $output;

    curl_close($ch);      
?>

浏览器执行,显示:

{"name":"Lei","msg":"Are you OK?"}

3. 如何上传和下载文件

已经和服务器勾搭上了,这时候得要个照片来看一看了吧,你也得把自己的照片发上去让人看一看了,虽然两个人在一起外貌不重要,但是男俊女靓总是最棒的。

3.1 传一张自己的照片过去表表诚意 —— POST上传文件

同样远程服务器端我们先传好一个接收脚本,接收图片并且保存到本地,注意文件和文件夹权限问题,需要有写入权限:

<?php
    if($_FILES){
        $filename = $_FILES[&#39;upload&#39;][&#39;name&#39;];
          $tmpname = $_FILES[&#39;upload&#39;][&#39;tmp_name&#39;];
          //保存图片到当前脚本所在目录
          if(move_uploaded_file($tmpname,dirname(__FILE__).&#39;/&#39;.$filename)){
            echo (&#39;上传成功&#39;);
          }
    }
?>

然后我们再来写我们本地服务器的php curl部分:

<?php 
    $data = array(&#39;name&#39;=>&#39;boy&#39;, "upload"=>"@boy.png");

    $ch = curl_init(); 

    curl_setopt($ch, CURLOPT_URL, "http://远程服务器地址马赛克/testRespond.php"); 
    curl_setopt($ch, CURLOPT_POST, 1);
    curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 60); 
    curl_setopt($ch, CURLOPT_POSTFIELDS , $data);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 

    $output = curl_exec($ch); 

    echo $output;

    curl_close($ch);         
?>

浏览器中运行一下,什么都米有,去看一眼远程的服务器,还是什么都没有,并没有上传成功。

为什么会这样呢?上面的代码应该是大家搜索curl php POST图片最常见的代码,这是因为我现在用的是PHP5.6以上版本,@符号在PHP5.6之后就弃用了,PHP5.3依旧可以用,所以有些同学发现能执行啊,有些发现不能执行,大抵是因为PHP版本的不同,而且curl在这两版本中实现是不兼容的,上面是PHP5.3的实现。

下面来讲PHP5.6及以后的实现,:

<?php 
    $data = array(&#39;name&#39;=>&#39;boy&#39;, "upload"=>"");
    $ch = curl_init(); 

    $data[&#39;upload&#39;]=new CURLFile(realpath(getcwd().&#39;/boy.png&#39;));

    curl_setopt($ch, CURLOPT_URL, "http://115.29.247.189/test/testRespond.php");
    curl_setopt($ch, CURLOPT_POST, 1);
    curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 60); 
    curl_setopt($ch, CURLOPT_POSTFIELDS , $data);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 

    $output = curl_exec($ch); 

    echo $output;

    curl_close($ch);         
?>

这里引入了一个CURLFile对象进行实现,关于此的具体可查阅文档进行了解。这时候再去远程服务器目录下看看,发现有了一张图片了,而且确实是我们刚才上传的图片。

3.2 获取远程服务器妹子的照片 —— 抓取图片

服务器妹子也挺实诚的,看了照骗觉得我长得挺慈眉善目的,就大方得拿出了她自己的照片,但是有点害羞的是,她不愿意主动拿过来,得我们自己去取。

远程服务器在她自己的目录下存放了一个图片叫girl.jpg,地址是她的web服务器根目录/girl.jpg,现在我要去获取这张照片。

<?php 
    $ch = curl_init(); 

    $fp=fopen(&#39;./girl.jpg&#39;, &#39;w&#39;);

    curl_setopt($ch, CURLOPT_URL, "http://远程服务器地址马赛克/girl.jpg"); 
    curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 60); 
    curl_setopt($ch, CURLOPT_FILE, $fp); 

    $output = curl_exec($ch); 
    $info = curl_getinfo($ch);

    fclose($fp);

    $size = filesize("./girl.jpg");
    if ($size != $info[&#39;size_download&#39;]) {
        echo "下载的数据不完整,请重新下载";
    } else {
        echo "下载数据完整";
    }

    curl_close($ch);    
?>

现在,在我们当前目录下就有了一张刚拿到的照片啦,是不是很激动呢!

这里值得一说的是curl_getinfo方法,这是一个获取本次请求相关信息的方法,对于调试很有帮助,要善用。

4. HTTP认证怎么搞

这个时候呢,服务器的家长说这个我们女儿还太小,不能找对象,就将她女儿关了起来,并且上了一个密码锁,所谓的HTTP认证,服务器呢偷偷托信鸽将HTTP认证的用户名和密码给了你,要你去见她,带她私奔。

那么拿到了用户名和密码,我们怎么通过PHP CURL搞定HTTP认证呢?

PS:这里偷懒就不去搭HTTP认证去试了,直接放一段代码,我们分析下。

function curl_auth($url,$user,$passwd){
    $ch = curl_init();
    curl_setopt_array($ch, [
        CURLOPT_USERPWD => $user.&#39;:&#39;.$passwd,
        CURLOPT_URL     => $url,
        CURLOPT_RETURNTRANSFER => true
    ]);
    $result = curl_exec($ch);
    curl_close($ch);
    return $result;
}

$authurl = &#39;http://要请求HTTP认证的地址&#39;;

echo curl_auth($authurl,&#39;vace&#39;,&#39;passwd&#39;);

这里有一个地方比较有意思:  
curl_setopt_array 这个方法可以通过数组一次性地设置多个参数,防止有些需要多处设置的出现密密麻麻的curl_setopt方法。

5.利用cookie模拟登陆

这时你成功见到了服务器妹子,想带她私奔,但是无奈没有盘缠走不远,服务器妹子说,她妈服务器上有金库,可以登陆上去搞一点下来。

首先我们先来分析一下,这个事情分两步,一是去登陆界面通过账号密码登陆,然后获取cookie,二是去利用cookie模拟登陆到信息页面获取信息,大致的框架是这样的。

<?php 
  //设置post的数据  
  $post = array ( 
    &#39;email&#39; => &#39;账户&#39;, 
    &#39;pwd&#39; => &#39;密码&#39;
  ); 
  //登录地址  
  $url = "登陆地址";  
  //设置cookie保存路径  
  $cookie = dirname(__FILE__) . &#39;/cookie.txt&#39;;  
  //登录后要获取信息的地址  
  $url2 = "登陆后要获取信息的地址";  
  //模拟登录 
  login_post($url, $cookie, $post);  
  //获取登录页的信息  
  $content = get_content($url2, $cookie);  
  //删除cookie文件 
  @ unlink($cookie);
     
  var_dump($content);    
?>

然后我们思考下下面两个方法的实现:

  • login_post($url, $cookie, $post)

  • get_content($url2, $cookie)

//模拟登录  
function login_post($url, $cookie, $post) { 
    $curl = curl_init();
    curl_setopt($curl, CURLOPT_URL, $url);
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, 0);
    curl_setopt($curl, CURLOPT_COOKIEJAR, $cookie);
    curl_setopt($curl, CURLOPT_POST, 1);
    curl_setopt($curl, CURLOPT_POSTFIELDS, http_build_query($post));
    curl_exec($curl); 
    curl_close($curl);
}
//登录成功后获取数据  
function get_content($url, $cookie) { 
    $ch = curl_init(); 
    curl_setopt($ch, CURLOPT_URL, $url); 
    curl_setopt($ch, CURLOPT_HEADER, 0); 
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
    curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie); 
    $rs = curl_exec($ch); 
    curl_close($ch); 
    return $rs; 
}

至此,总算是模拟登陆成功,一切顺利啦,通过php CURL“撩”服务器就是这么简单。

当然,CURL的能力远不止于此,本文仅希望就后端PHP开发中最常用的几种场景做一个整理和归纳。最后一句话,具体问题具体分析。

相关推荐:

php curl带有csrf-token验证模拟提交方法

PHP CURL与java http如何使用

php curl错误排查的方法详解

위 내용은 PHP에서 CURL을 사용하는 PHP 컬의 자세한 분석 및 일반적인 함정의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.