php采用curl访问域名返回405 method not allowed提示的解决方法

<div class="jb51code">
<pre class="brush:PHP;">
/**

  • http测试
  • 注:PHP版本5.2以上才支持CURL_IPRESOLVE_V4
  • @param $url 网站域名
  • @param $type 网站访问协议
  • @param $ipresolve 解析方式
    */
    public function web_http($url,$type,$ipresolve) {
    //设置Header头
    $header[] = "Accept: application/json";
    $header[] = "Accept-Encoding: gzip";
    $httptype = function_exists('curl_init');
    if (!$httptype) {
    $html = file_get_contents($url);
    } else {
    $ch = curl_init();
    curl_setopt($ch,CURLOPT_URL,$url);
    //输出头信息
    curl_setopt($ch,CURLOPT_HEADER,1);
    //递归访问location跳转链接,直到返回200OK
    curl_setopt($ch,CURLOPT_FOLLOWLOCATION,1);
    //不对HTML中的BODY部分进行输出
    curl_setopt($ch,CURLOPT_NOBODY,1);
    //将结果以文件流的方式返回,不是直接输出
    curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);
    //以IPv4/IPv6的方式访问
    if($ipresolve=='ipv6') {
    curl_setopt($ch,CURLOPT_IPRESOLVE,CURL_IPRESOLVE_V6);
    }else{
    curl_setopt($ch,CURL_IPRESOLVE_V4);
    }
    //添加HTTP header头采用压缩和GET方式请求
    curl_setopt( $ch,CURLOPT_HTTPHEADER,$header );
    curl_setopt($ch,CURLOPT_ENCODING,"gzip");
    curl_setopt($ch,CURLOPT_CUSTomrEQUEST,'GET');
    //清除DNS缓存
    curl_setopt($ch,CURLOPT_DNS_CACHE_TIMEOUT,0);
    //设置连接超时时间
    curl_setopt($ch,CURLOPT_CONNECTTIMEOUT,15);
    //设置访问超时
    curl_setopt($ch,CURLOPT_TIMEOUT,50);
    //设置User-agent
    curl_setopt($ch,CURLOPT_USERAGENT,'Mozilla/5.0 (Windows NT 6.1) AppleWebKit/536.11 (KHTML,like Gecko) Chrome/20.0.1132.47 Safari/536.11');
    if($type=="https") {
    //不对认证证书来源的检查
    curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false);
    //从证书中检查SSL加密算法是否存在
    curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,true);
    }
    //执行Curl操作
    $html = curl_exec($ch);
    //获取一个cURL连接资源句柄的信息(获取最后一次传输的相关信息)
    $info = curl_getinfo($ch);
    curl_close($ch);
    }
    return $info;
    }

以上为一个基本curl访问的方法,由于这里需要通过使用IPv6的方式,所以加了相应的选项,相信大家能看的明白,平时经常用到的选项上面都有出现,大家根据需要取舍。

状态码提示405/Method Not Allowed表示不支持请求的方法,这个错误并不常见。

导致这个错误是要是

由于curl认是采用post方式进行提交访问的,post方式在此类域名下是没有权限

,比如在测试www.amazon.cn的时候就出现了这类问题,而修改为get的方式,并且增加了header头后,即可正常访问,个人推测,或许是亚马逊那边基本上都是采用get的方式,才会被认为是人为的点击,对post做了相应屏蔽

对此增加了如下代码

rush:PHP;"> //设置Header头 $header[] = "Accept: application/json"; $header[] = "Accept-Encoding: gzip"; //添加HTTP header头采用压缩和GET方式请求 curl_setopt( $ch,$header ); curl_setopt($ch,"gzip"); curl_setopt($ch,'GET');

命令行的形式为:

rush:PHP;"> curl -v www.amazon.cn

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...