PHP使用CURL模拟POST/GET/PUT/DELETE方式提交数据

2019-05-05 14:04:11

  最近因为工作需要,调用网盘接口来上传文件,我用了CURL库, 当然在用CURL库之前必须要在php中启用 cURL 设置


  可以通过使用php_info()函数来得到cURL信息,如果看不到cURL信息的话,那么需要设置PHP并开启这个库。在Windows平台下,需要改一改php.ini文件的设置,找到    php_curl.dll,并取消前面的分号注释就行了。


   一般的文件上传是通过html表单进行的,通过CURL可以不经过浏览器,直接在服务器端模拟进行表单提交,完成POST数据、文件上传等功能。


   我们是可以通过其他办法获取网页内容。大多数时候,我因为想偷懒,都直接用简单的PHP函数,如下:


  $content = file_get_contents("http://www.doucube.com");

  // or

  $lines = file("http://www.doucube.com");

  // or

  readfile(http://www.doucube.com);


   不过,这种做法缺乏灵活性和有效的错误处理。而且,你也不能用它完成一些高难度任务——比如处理coockies、验证、表单提交、文件上传等等。所以选择curl库。 


示例代码:


<?php

    $url = 'https://www.google.com';

    $method = 'POST';

     

    //headers and data (this is API dependent, some uses XML):

    //即在接口调用时才用headers 和$data

    $headers = array(

    'Accept: application/json',

    'Content-Type: application/json',

    );

    $data = json_encode(array(

    'firstName'=> 'John',

    'lastName'=> 'Doe'

    ));


    // 启动一个CURL会话

    $handle = curl_init(); 

    curl_setopt($handle, CURLOPT_URL, $url); // 要访问的地址

    curl_setopt($handle,CURLOPT_HEADER,1); // 是否显示返回的Header区域内容

    curl_setopt($handle, CURLOPT_HTTPHEADER, $headers); //设置请求头

    curl_setopt($handle, CURLOPT_RETURNTRANSFER, true); // 获取的信息以文件流的形式返回

    curl_setopt($handle, CURLOPT_SSL_VERIFYHOST, false); // 从证书中检查SSL加密算法是否存在

    curl_setopt($handle, CURLOPT_SSL_VERIFYPEER, false); // 对认证证书来源的检查

     

    switch($method) {

    case 'GET':

    break;

    case 'POST':

    curl_setopt($handle, CURLOPT_POST, true);

    curl_setopt($handle, CURLOPT_POSTFIELDS, $data); //设置请求体,提交数据包

    break;

    case 'PUT':

    curl_setopt($handle, CURLOPT_CUSTOMREQUEST, 'PUT');

    curl_setopt($handle, CURLOPT_POSTFIELDS, $data); //设置请求体,提交数据包

    break;

    case 'DELETE':

    curl_setopt($handle, CURLOPT_CUSTOMREQUEST, 'DELETE');

    break;

    }

     

    $response = curl_exec($handle); // 执行操作

    $code = curl_getinfo($handle, CURLINFO_HTTP_CODE); // 获取返回的状态码

    curl_close ($handle); // 关闭CURL会话

    if('200'==$code){

      echo "ok";

    }

    


    下面还有一个示例,有兴趣可以看看:


用curl上传文件的话很方便,什么header,post串都不用生成了,用fsockopen要写一堆 curl: ==============


PHP code 


$file = array("upimg"=>"@E:/png.png");//文件路径,前面要加@,表明是文件上传. 


$curl = curl_init("http://localhost/a.php"); 


curl_setopt($curl,CURLOPT_POST,true); 


curl_setopt($curl,CURLOPT_POSTFIELDS,$file); 


curl_exec($curl);






fsockopen: ===============


PHP code $uploadFile = file_get_contents("E:/png.png"); $boundary   = md5(time());


$postStr .="--".$boundary."\r\n";//边界开始,注意默认比header定义的boundary多两个'-' 


$postStr .="Content-Disposition: form-data; name=\"upimg\"; filename=\"E:/png.png\"\r\n"; 


$postStr .="Content-Type: image/png\r\n\r\n"; 


$postStr .=$uploadFile."\r\n"; $postStr .="--".$boundary."\r\n";//边界结束 


write($fp,"POST /a.php HTTP/1.0\r\n"); 


fwrite($fp,"Content-Type: multipart/form-data; boundary=".$boundary."\r\n"); 


fwrite($fp,"Content-length:".strlen($postStr)."\r\n\r\n"); 


fwrite($fp,$postStr); 


while (!feof($fp))


{      


echo fgets($fp, 128); 



fclose($fp);



  • 2019-12-11 16:18:51

    npm发布vue组件

    开发之前先看看官网的 开发规范 我们开发的之后期望的结果是支持 import、require 或者直接使用 script 标签的形式引入,就像这样

  • 2019-12-11 16:21:00

    .vue文件 加scoped 样式不起作用

    在vue组件中,为了使样式私有化(模块化),不对全局造成污染,在style标签上添加scoped属性,以表示它只属于当下的模块。但是要慎用,因为在我们需要修改公共组件(第三方库或者项目中定制的组件)的样式的时候,scoped会造成很多困难,组要增加额外的复杂度。

  • 2019-12-11 16:22:04

    Vue中的scoped和scoped穿透,scoped原理

    在Vue文件中的style标签上有一个特殊的属性,scoped。当一个style标签拥有scoped属性时候,它的css样式只能用于当前的Vue组件,可以使组件的样式不相互污染。如果一个项目的所有style标签都加上了scoped属性,相当于实现了样式的模块化。

  • 2019-12-12 14:19:32

    laravel自定义分页LengthAwarePaginator

    有时候我们使用larave提供的后台分页数据库查询,有时候限制太多,我们需要自己定制分页功能。 下面是我给大家一个例子,我们可以根据例子,制作自己的分页功能。

  • 2019-12-14 21:04:05

    聊聊keep-alive组件的使用及其实现原理

    keep-alive是Vue.js的一个内置组件。它能够不活动的组件实例保存在内存中,而不是直接将其销毁,它是一个抽象组件,不会被渲染到真实DOM中,也不会出现在父组件链中。 它提供了include与exclude两个属性,允许组件有条件地进行缓存。

  • 2019-12-14 21:06:58

    vue----keep-alive缓存,activated,deactivated两个生命周期函数,,meta实现缓存

    如果没有缓存,每点击一次导航,内容区就会创建一个组件,该组件会经历整个生命周期,每点击一次,就会创建一个组件,比较浪费性能, 这时,我们就要考虑到是否能将点击过的已创建的组件进行缓存,当再次点击已访问过的组件时,这时,就会从缓存中获取该组件,而不会重新创建,