Maison > développement back-end > Problème PHP > Comment convertir curl en php

Comment convertir curl en php

藏色散人
Libérer: 2023-03-13 17:32:01
original
2080 Les gens l'ont consulté

Comment convertir curl en php : 1. Obtenez le statut via "curl -X GET -H "Content-Type:application"..." ; 2. Définissez le statut 3. Via "$header= array(. ..) La méthode " peut être utilisée pour convertir curl en php et l'envoyer.

Comment convertir curl en php

L'environnement d'exploitation de cet article : système windows7, version PHP7.1, ordinateur DELL G3

Comment convertir curl en php ? La commande curl est convertie en code source php. rreeeensemble status:

curl -X GET -H "Content-Type:application/json" -H "Authorization: token 4e56266f2502936e0378ea6a985dc74a5bec4280" http://user.endv.cn/v1/datastreams/plug-status/datapoint/
Copier après la connexion

Utiliser php curl pour envoyer des données json est la même chose que curl post d'autres données

Laissez-moi résumer quelques exemples de curl post envoyant des données json

Exemple 1

{"status": 200, "datapoint": null}
Copier après la connexion

Exemple 2

curl  -H "Authorization: token 6bcb3cdb69b07370f5ad73e7a856409802fdd735" -d "{\"datapoint\":{\"x\":1}}" http://user.endv.cn/v1/datastreams/plug-status/datapoint/?deliver_to_device=true
Copier après la connexion

Exemple 3

{"status": 404, "nonce": 333984364, "message": "remote device is disconnect"}
Copier après la connexion

envoi et réception de post curl

Copier après la connexion

Copier après la connexion

get test

$data = array("name" => "Hagrid", "age" => "36");                                                                      
$data_string = json_encode($data);                                                                                     
   
$ch = curl_init('http://api.local/rest/users');                                                                        
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");                                                                       
curl_setopt($ch, CURLOPT_POSTFIELDS, $data_string);                                                                   
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);                                                                        
curl_setopt($ch, CURLOPT_HTTPHEADER, array(                                                                            
    'Content-Type: application/json',                                                                                  
    'Content-Length: ' . strlen($data_string))                                                                         
);                                                                                                                     
   
$result = curl_exec($ch);
Copier après la connexion

Une brève introduction à l'utilisation de curl

Curl est un outil en ligne de commande http très puissant sous Linux, et ses fonctions sont très puissant.

1) Sans plus attendre, commençons par là !

function http_post_data($url, $data_string) {  
  
        $ch = curl_init();  
        curl_setopt($ch, CURLOPT_POST, 1);  
        curl_setopt($ch, CURLOPT_URL, $url);  
        curl_setopt($ch, CURLOPT_POSTFIELDS, $data_string);  
        curl_setopt($ch, CURLOPT_HTTPHEADER, array(  
            'Content-Type: application/json; charset=utf-8',  
            'Content-Length: ' . strlen($data_string))  
        );  
        ob_start();  
        curl_exec($ch);  
        $return_content = ob_get_contents();  
        ob_end_clean();  
  
        $return_code = curl_getinfo($ch, CURLINFO_HTTP_CODE);  
        return array($return_code, $return_content);  
    }  
  
$url  = "http://xx.xx.cn";  
$data = json_encode(array('a'=>1, 'b'=>2));  
  
list($return_code, $return_content) = http_post_data($url, $data);
Copier après la connexion

Après avoir appuyé sur Entrée, le html de code.endv.cn s'affichera à l'écran ~

2) Eh bien, si vous souhaitez enregistrer la page que vous avez lue, est-ce ainsi qu'elle devrait être ?

$data=' {  
     "button":[  
     {      
          "type":"click",  
          "name":"今日歌曲",  
          "key":"V1001_TODAY_MUSIC"  
      },  
      {  
           "type":"click",  
           "name":"歌手简介",  
           "key":"V1001_TODAY_SINGER"  
      },  
      {  
           "name":"菜单",  
           "sub_button":[  
            {  
               "type":"click",  
               "name":"hello word",  
               "key":"V1001_HELLO_WORLD"  
            },  
            {  
               "type":"click",  
               "name":"赞一下我们",  
               "key":"V1001_GOOD"  
            }]  
       }]  
 }';  
  
$ch = curl_init($urlcon); //请求的URL地址  
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");  
curl_setopt($ch, CURLOPT_POSTFIELDS, $data);//$data JSON类型字符串  
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);  
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: application/json', 'Content-Length: ' . strlen($data)));  
$data = curl_exec($ch);  
print_r($data);//创建成功返回:{"errcode":0,"errmsg":"ok"}
Copier après la connexion

Bien sûr que vous pouvez, mais cela ne doit pas nécessairement être si gênant !

Utilisez simplement l'option intégrée de curl. Pour enregistrer les résultats http, utilisez cette option : -o

<?php
    $url = "http://localhost/web_services.php";
    $post_data = array ("username" => "bob","key" => "12345");
    $ch = curl_init();
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    // post数据
    curl_setopt($ch, CURLOPT_POST, 1);
    // post的变量
    curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data);
    
    $output = curl_exec($ch);
    curl_close($ch);
    
    //打印获得的数据
    print_r($output);
?>
Copier après la connexion

De cette façon, vous pouvez voir un indicateur de progression de la page de téléchargement apparaître à l'écran. Quand la progression atteindra 100%, tout ira bien

3) Quoi ? ! Vous ne pouvez pas accéder ? Il faut que votre proxy ne soit pas configuré.

Lorsque vous utilisez curl, vous pouvez utiliser cette option pour spécifier le serveur proxy et son port utilisé pour l'accès http : -x

<html>
<body>
Welcome <?php echo $_POST["username"]; ?>.<br />
You are <?php echo $_POST["key"]; ?> years old.
</body>
</html>
Copier après la connexion

4) C'est ennuyeux lors de la visite de certains sites Web. Ils utilisent des cookies pour enregistrer les informations de session.

Les navigateurs comme IE/NN peuvent certainement gérer facilement les informations sur les cookies, mais qu'en est-il de notre curl ? .....

Apprenons cette option : -D <— Ceci permet d'enregistrer les informations du cookie dans la réponse http dans un fichier spécial

//curl -X GET -H "Content-Type:application/json" -H "Authorization: token 4e56266f2502936e0378ea6a985dc74a5bec4280" http://user.endv.cn/v1/datastreams/plug-status/datapoint/ 
    $url = "http://localhost/web_services.php";
    $post_data = array ("username" => "bob","key" => "12345");
    $ch = curl_init();
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
        
    $output = curl_exec($ch);
    curl_close($ch);
    
    //打印获得的数据
    print_r($output);
Copier après la connexion

De cette façon, lorsque la page est enregistrée dans page.html À la en même temps, les informations des cookies sont également stockées dans cookie0001.txt

5) Alors, comment continuer à utiliser les informations des cookies laissées la dernière fois lors de votre prochaine visite ? Vous savez, de nombreux sites Web s'appuient sur la surveillance des informations relatives à vos cookies pour déterminer si vous visitez leur site Web en violation des règles.

Cette fois, nous utilisons cette option pour ajouter les dernières informations du cookie à la requête http : -b

$ curl http://code.endv.cn
Copier après la connexion

De cette façon, nous pouvons simuler presque toutes les opérations d'IE pour accéder à la page Web !

6) Attendez un instant~Il semble que j'ai oublié quelque chose~

C'est vrai ! Ce sont des informations sur le navigateur

Certains sites Web ennuyeux nous obligent toujours à utiliser certains navigateurs spécifiques pour y accéder. Parfois, ce qui est encore pire, c'est que nous devons utiliser certaines versions spécifiques de NND. Où avons-nous le temps de trouver ces choses étranges. ? navigateur! ?

Heureusement, curl nous offre une option utile, qui nous permet de spécifier arbitrairement les informations du navigateur que nous déclarons pour cette visite : -A

$ curl http://code.endv.cn > page.html
Copier après la connexion

De cette façon, lorsque le serveur recevra la demande d'accès, il pensera que vous l'êtes IE6.0 fonctionne-t-il sous Windows 2000. Hé, hé, vous utilisez peut-être un Mac !

Et "Mozilla/4.73 [en] (X11; U; Linux 2.2; 15 i686" peut indiquer à l'autre partie que vous utilisez Linux sur un PC, en utilisant Netscape 4.73, hahaha

7) Un autre Une restriction couramment utilisée La méthode côté serveur consiste à vérifier le référent pour l'accès http. Par exemple, si vous visitez d'abord la page d'accueil, puis visitez la page de téléchargement qui y est spécifiée, l'adresse de référence de la deuxième visite sera l'adresse de la page après la première visite réussie. De cette façon, tant que le serveur constate que l'adresse du référent d'une certaine visite sur la page de téléchargement n'est pas l'adresse de la page d'accueil, il peut conclure qu'il s'agit d'une connexion volée ~

Je déteste ça~Je veux juste voler la connexion ~ ! !

Heureusement, curl nous offre la possibilité de définir le référent : -e

$ curl -o page.html http://code.endv.cn
Copier après la connexion

De cette façon, vous pouvez tromper le serveur de l'autre partie. Vous avez cliqué sur un lien de mail.linuxidc.com, hahaha

8) Comme je l'ai fait. J'écrivais, j'ai découvert que j'avais raté quelque chose d'important ! ——-Utilisez curl pour télécharger des fichiers

Comme je viens de le dire, pour télécharger une page dans un fichier, vous pouvez utiliser -o, et il en va de même pour le téléchargement de fichiers. Par exemple,

$ curl -x 123.45.67.89:1080 -o page.html http://code.endv.cn
Copier après la connexion

Ici nous vous apprenons une nouvelle option : -O majuscule O, utilisez-la comme ceci :

$ curl -x 123.45.67.89:1080 -o page.html -D cookie0001.txt http://code.endv.cn
Copier après la connexion

De cette façon, vous pouvez l'enregistrer automatiquement localement en fonction du nom du fichier sur le serveur !

En voici un autre qui est plus utile.

Si en plus de screen1.JPG il y a screen2.JPG, screen3.JPG, ...., screen10.JPG qui doivent être téléchargés, est-il possible que nous devions écrire un script pour effectuer ces opérations ?

Pas plus !

En curl, écris juste comme ceci :

$ curl -x 123.45.67.89:1080 -o page1.html -D cookie0002.txt -b cookie0001.txt http://code.endv.cn
Copier après la connexion

Hehehe, c'est pas génial ? ! ~

9) Revenez, continuons à expliquer le téléchargement !

$ curl -A "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)" -x 123.45.67.89:1080 -o page.html -D cookie0001.txt http://code.endv.cn
Copier après la connexion

Le téléchargement généré de cette manière est

$ curl -A "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)" -x 123.45.67.89:1080 -e "mail.linuxidc.com" -o page.html -D cookie0001.txt http://code.endv.cn
Copier après la connexion

assez pratique, n'est-ce pas ? Hahaha

hein ? Il est trop tôt pour être heureux.

Étant donné que les noms de fichiers sous zzh/nick sont tous 001, 002..., 201, les fichiers téléchargés portent le même nom, et les derniers écrasent les fichiers précédents ~

没关系,我们还有更狠的!

$ curl -o #2_#1.jpg http://img.endv.cn/~{zzh,nick}/[001-201].JPG
Copier après la connexion

—这是.....自定义文件名的下载? —对头,呵呵!

这样,自定义出来下载下来的文件名,就变成了这样:原来: ~zzh/001.JPG —-> 下载后: 001-zzh.JPG 原来: ~nick/001.JPG —-> 下载后: 001-nick.JPG

这样一来,就不怕文件重名啦,呵呵

9)继续讲下载

我们平时在windows平台上,flashget这样的工具可以帮我们分块并行下载,还可以断线续传。curl在这些方面也不输给谁,嘿嘿

比如我们下载screen1.JPG中,突然掉线了,我们就可以这样开始续传

$ curl -c -O http://cgi2.tky.3wb.ne.jp/~zzh/screen1.JPG
Copier après la connexion

当然,你不要拿个flashget下载了一半的文件来糊弄我 别的下载软件的半截文件可不一定能用哦 ~

分块下载,我们使用这个option就可以了: -r

举例说明

比如我们有一个http://img.endv.cn/~zzh/zhao1.mp3 要下载(赵老师的电话朗诵 :D )我们就可以用这样的命令:

$ curl -r 0-10240 -o "zhao.part1" http:/img.endv.cn/~zzh/zhao1.mp3 &\
$ curl -r 10241-20480 -o "zhao.part1" http:/img.endv.cn/~zzh/zhao1.mp3 &\
$ curl -r 20481-40960 -o "zhao.part1" http:/img.endv.cn/~zzh/zhao1.mp3 &\
$ curl -r 40961- -o "zhao.part1" http:/img.endv.cn/~zzh/zhao1.mp3
Copier après la connexion

这样就可以分块下载啦。不过你需要自己把这些破碎的文件合并起来如果你用UNIX或苹果,用 cat zhao.part* > zhao.mp3就可以如果用的是Windows,用copy /b 来解决吧,呵呵

上面讲的都是http协议的下载,其实ftp也一样可以用。用法嘛,

$ curl -u name:passwd ftp://ip:port/path/file
Copier après la connexion

或者大家熟悉的

$ curl ftp://name:passwd@ip:port/path/file
Copier après la connexion

10) 说完了下载,接下来自然该讲上传咯上传的option是 -T

比如我们向ftp传一个文件:

$ curl -T localfile -u name:passwd ftp://upload_site:port/path/
Copier après la connexion

当然,向http服务器上传文件也可以比如

$ curl -T localfile http://img.endv.cn/~zzh/abc.cgi
Copier après la connexion

注意,这时候,使用的协议是HTTP的PUT method

刚才说到PUT,嘿嘿,自然让老服想起来了其他几种methos还没讲呢! GET和POST都不能忘哦。

http提交一个表单,比较常用的是POST模式和GET模式

GET模式什么option都不用,只需要把变量写在url里面就可以了比如:

$ curl http://code.endv.cn/login.cgi?user=nickwolfe&password=12345
Copier après la connexion

而POST模式的option则是 -d

比如,

$ curl -d "user=nickwolfe&password=12345" http://code.endv.cn/login.cgi
Copier après la connexion

就相当于向这个站点发出一次登陆申请 ~

到底该用GET模式还是POST模式,要看对面服务器的程序设定。

一点需要注意的是,POST模式下的文件上的文件上传,比如

<form method="POST" enctype="multipar/form-data" action="http://img.endv.cn/~zzh/up_file.cgi">
<input type=file name=upload>
<input type=submit name=nick value="go">
</form>
Copier après la connexion

这样一个HTTP表单,我们要用curl进行模拟,就该是这样的语法:

$ curl -F upload=@localfile -F nick=go http://img.endv.cn/~zzh/up_file.cgi
Copier après la connexion

罗罗嗦嗦讲了这么多,其实curl还有很多很多技巧和用法比如 https的时候使用本地证书,就可以这样

$ curl -E localcert.pem https://remote_server
Copier après la connexion

再比如,你还可以用curl通过dict协议去查字典 ~

$ curl dict://dict.org/d:computer
Copier après la connexion

推荐学习:《PHP视频教程

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

É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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal