Heim > Artikel > Backend-Entwicklung > Detaillierte Analyse und Problemzusammenfassung von PHP mit Curl
Wir stellen das heutige Tool vor: CURL (Client URL Library). Natürlich werde ich dieses Tool heute in PHP verwenden.
0. Was ist Curl?
PHP supports libcurl, a library created by Daniel Stenberg, that allows you to connect and communicate to many different types of servers with many different types of protocols. libcurl currently supports the http, https, ftp, gopher, telnet, dict, file, and ldap protocols. libcurl also supports HTTPS certificates, HTTP POST, HTTP PUT, FTP uploading (this can also be done with PHP's ftp extension), HTTP form based upload, proxies, cookies, and user+password authentication.
Dies ist eine Erklärung von Curl in PHP. Einfach ausgedrückt ist Curl eine Bibliothek, die es Ihnen ermöglicht, URLs und viele verschiedene Servertypen zu übergeben Kontakte knüpfen, chatten und intensive Gespräche führen und unterstützt außerdem viele Protokolle. Und die Leute sagten auch, dass Curl https-Authentifizierung, HTTP-Post, FTP-Upload, Proxy, Cookies, einfache Passwortauthentifizierung und andere Funktionen unterstützen kann.
Nachdem ich so viel gesagt habe, habe ich eigentlich nicht viel davon, ich kann es nur in der Anwendung spüren. Zuerst musste ich eine POST-Anfrage an einen anderen Server auf der Serverseite initiieren mit Curl in Kontakt zu kommen, und dann habe ich es gespürt.
Bevor ich offiziell über die Verwendung spreche, möchte ich erwähnen, dass Sie zuerst das Curl-Modul in Ihrer PHP-Umgebung installieren und aktivieren müssen. Ich werde nicht auf die spezifische Methode eingehen. Sie können es auf Google überprüfen. Es ist ganz einfach, es auszuprobieren, oder schauen Sie sich die offizielle PHP-Dokumentation an.
1. Holen Sie es sich und probieren Sie es zuerst aus.
Sobald Sie das Tool erhalten haben, müssen Sie zuerst damit spielen und versuchen, zu sehen, ob es reibungslos funktioniert. Andernfalls sollten Sie es so schnell wie möglich verwenden Sobald Sie es erhalten, wird Ihr eigener Code durcheinander gebracht. Wie wäre es, wenn Sie den Server necken?
Nehmen wir zum Beispiel Baidu, die berühmte Website zum Testen von Netzwerkverbindungen, und versuchen Sie es mit Curl
<?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); ?>
Wenn Sie diese PHP-Datei im Browser der lokalen Umgebung öffnen, Die angezeigte Seite ist Baidus Homepage. Was ist mit dem „localhost“, den ich gerade eingegeben habe?
Der obige Code und die Kommentare haben vollständig erklärt, was dieser Code tut.
$ch = curl_init(), erstellt eine Curl-Sitzungsressource und gibt erfolgreich ein Handle zurück
curl_setopt($ch, CURLOPT_URL, „baidu.com“), legt natürlich die URL fest;
Die beiden oben genannten Sätze können zu einem Satz kombiniert werden $ch = curl_init("baidu.com");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 0) Hiermit wird festgelegt, ob gespeichert werden soll das Antwortergebnis wird in einer Variablen gespeichert, 0 wird direkt wiedergegeben;
$output = curl_exec($ch) wird ausgeführt und dann wird das Antwortergebnis in der $output-Variablen für das folgende Echo gespeichert;
curl_close($ ch) Schließt diese Curl-Sitzungsressource.
Die Verwendung von Curl in PHP sieht ungefähr so aus. Der zweite Schritt, das Festlegen von Parametern über die Methode „curl_setopt“, ist der komplizierteste und wichtigste. Wenn Sie interessiert sind, können Sie die offizielle detaillierte Referenz zu einstellbaren Parametern lesen . Es ist lang genug, dass man sich übergeben möchte, aber bei Bedarf macht Übung den Meister.
Zusammenfassend lässt sich sagen, dass die Verwendung von Curl in PHP wie folgt ist: Curl-Sitzung erstellen -> Konfigurationsparameter ->
Sehen wir uns einige häufige Szenarien an, wie wir uns „anziehen“ müssen (Konfigurationsparameter), um „Mädchen richtig abzuholen“ (den Server richtig abzuholen).
2. Sagen Sie „Hallo“ – GET- und POST-Anfragen und HTTPS-Protokollverarbeitung
Sagen Sie zuerst „Hallo“ zum Server, senden Sie „Hallo“ an den Server und sehen Sie, wie er reagiert. Dies ist einfach der bequemste Weg Senden Sie eine GET-Anfrage an den Server. Natürlich ist auch eine kleine Notiz wie POST in Ordnung.
2.1 GET-Anfrage
Nehmen wir als Beispiel „Suche nach Schlüsselwörtern auf einer berühmten Gay-Dating-Website 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); ?>
Es scheint sich nicht vom vorherigen zu unterscheiden Hier sind jedoch zwei Punkte, die erwähnt werden können:
1. Die Standardanforderungsmethode ist GET, daher ist es nicht erforderlich, die GET-https-Anfrage explizit anzugeben. Nicht-HTTP-Anfrage: Ich habe an verschiedenen Stellen gesehen, dass bei HTTPS-Anfragen einige Codezeilen hinzugefügt werden müssen, um die SSL-Zertifikatsprüfung zu umgehen und Ressourcen erfolgreich anzufordern. Dies scheint hier jedoch nicht erforderlich zu sein.
The two Curl options are defined as: CURLOPT_SSL_VERIFYPEER - verify the peer's SSL certificate CURLOPT_SSL_VERIFYHOST - verify the certificate's name against host They both default to true in Curl, and shouldn't be disabled unless you've got a good reason. Disabling them is generally only needed if you're sending requests to servers with invalid or self-signed certificates, which is only usually an issue in development. Any publicly-facing site should be presenting a valid certificate, and by disabling these options you're potentially opening yourself up to security issues.Das heißt, sofern kein illegales oder hausgemachtes Zertifikat verwendet wird, was meist in der Entwicklungsumgebung vorkommt, sollten Sie diese beiden Zeilen auf „false“ setzen, um eine SSL-Zertifikatsprüfung zu vermeiden, andernfalls besteht keine Notwendigkeit, dies zu tun Wenn Sie dies nicht tun, ist dies nicht sicher. 2.2 POST-AnfrageWie stellt man also eine POST-Anfrage? Übergeben Sie zum Testen zunächst ein Skript zum Empfangen von POST auf einem Testserver:
//testRespond.php <?php $phpInput=file_get_contents('php://input'); echo urldecode($phpInput); ?>Senden Sie normale Daten und schreiben Sie dann lokal eine Anfrage:
<?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); ?>The Das Ergebnis der Browserausführung ist: name=Lei&msg=Sind Sie in Ordnung?
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 60) legt die längste tolerierbare Verbindungszeit in Sekunden fest. Sie können nicht ewig warten und eine Mumie werden ($ch, CURLOPT_POSTFIELDS, http_build_query($data)) legt das Datenfeld von POST fest. Da es sich um Array-Daten handelt (das JSON-Format wird später erläutert), verwenden Sie http_build_query, um es zu verarbeiten.
Was ist mit JSON-Daten? Wie stelle ich eine POST-Anfrage?
<?php $data='{"name":"Lei","msg":"Are you OK?"}'; $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('Content-Type: application/json', 'Content-Length:' . 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:Geht es dir gut?"}
3. So laden Sie Dateien hoch und laden sie herunter
wurde mit dem Server verbunden Jetzt müssen Sie ein Foto machen, um es sich anzusehen. Sie müssen auch Ihr eigenes Foto veröffentlichen, damit andere es sich ansehen können. Obwohl das Aussehen zweier Menschen zusammen nicht wichtig ist, sind ein gutaussehender Mann und eine schöne Frau immer das Beste.
3.1 Senden Sie ein Foto von sich selbst, um Ihre Aufrichtigkeit zu zeigen – POST-Upload-Datei
Ähnlich wie beim Remote-Server senden wir zunächst ein Empfangsskript, um das Bild zu empfangen und es lokal zu speichern Bei Datei- und Ordnerberechtigungsproblemen ist eine Schreibberechtigung erforderlich:
<?php if($_FILES){ $filename = $_FILES['upload']['name']; $tmpname = $_FILES['upload']['tmp_name']; //保存图片到当前脚本所在目录 if(move_uploaded_file($tmpname,dirname(__FILE__).'/'.$filename)){ echo ('上传成功'); } } ?>
然后我们再来写我们本地服务器的php curl部分:
<?php $data = array('name'=>'boy', "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('name'=>'boy', "upload"=>""); $ch = curl_init(); $data['upload']=new CURLFile(realpath(getcwd().'/boy.png')); 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('./girl.jpg', 'w'); 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['size_download']) { 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.':'.$passwd, CURLOPT_URL => $url, CURLOPT_RETURNTRANSFER => true ]); $result = curl_exec($ch); curl_close($ch); return $result; } $authurl = 'http://要请求HTTP认证的地址'; echo curl_auth($authurl,'vace','passwd');
这里有一个地方比较有意思: curl_setopt_array 这个方法可以通过数组一次性地设置多个参数,防止有些需要多处设置的出现密密麻麻的curl_setopt方法。 5.利用cookie模拟登陆 这时你成功见到了服务器妹子,想带她私奔,但是无奈没有盘缠走不远,服务器妹子说,她妈服务器上有金库,可以登陆上去搞一点下来。 首先我们先来分析一下,这个事情分两步,一是去登陆界面通过账号密码登陆,然后获取cookie,二是去利用cookie模拟登陆到信息页面获取信息,大致的框架是这样的。
<?php //设置post的数据 $post = array ( 'email' => '账户', 'pwd' => '密码' ); //登录地址 $url = "登陆地址"; //设置cookie保存路径 $cookie = dirname(__FILE__) . '/cookie.txt'; //登录后要获取信息的地址 $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详细解析及问题汇总相关文章请关注PHP中文网!