当前位置:首页 > PHP教程 > php应用 > 列表

php使用curl伪造浏览器访问操作示例

发布:smiling 来源: PHP粉丝网  添加日期:2021-12-25 16:27:17 浏览: 评论:0 

这篇文章主要介绍了php使用curl伪造浏览器访问操作,结合实例形式分析了php使用curl伪造浏览器访问的原理与具体实现技巧,需要的朋友可以参考下。

本文实例讲述了php使用curl伪造浏览器访问操作,分享给大家供大家参考,具体如下:

原理

服务器主要通过User-Agent识别客户端是何种设备

User-Agent是Http协议中的一部分,属于头域的组成部分。基本格式为: 浏览器标识 (操作系统标识; 加密等级标识; 浏览器语言) 渲染引擎标识 版本信息。

具体方法如下

  1. /** 
  2.  * curl获取数据 
  3.  * @param $url 
  4.  * @return mixed 
  5.  */ 
  6. function get_url($url
  7.   $ifpost = 0; 
  8.   $datafields = ''
  9.   $cookiefile = ''
  10.   $v = false; 
  11.   //构造随机ip 
  12.   $ip_long = array
  13.     array('607649792''608174079'), //36.56.0.0-36.63.255.255 
  14.     array('1038614528''1039007743'), //61.232.0.0-61.237.255.255 
  15.     array('1783627776''1784676351'), //106.80.0.0-106.95.255.255 
  16.     array('2035023872''2035154943'), //121.76.0.0-121.77.255.255 
  17.     array('2078801920''2079064063'), //123.232.0.0-123.235.255.255 
  18.     array('-1950089216''-1948778497'), //139.196.0.0-139.215.255.255 
  19.     array('-1425539072''-1425014785'), //171.8.0.0-171.15.255.255 
  20.     array('-1236271104''-1235419137'), //182.80.0.0-182.92.255.255 
  21.     array('-770113536''-768606209'), //210.25.0.0-210.47.255.255 
  22.     array('-569376768''-564133889'), //222.16.0.0-222.95.255.255 
  23.   ); 
  24.   $rand_key = mt_rand(0, 9); 
  25.   $ip= long2ip(mt_rand($ip_long[$rand_key][0], $ip_long[$rand_key][1])); 
  26. //模拟http请求header头 
  27.   $header = array("Connection: Keep-Alive","Accept: text/html, application/xhtml+xml, */*""Pragma: no-cache""Accept-Language: zh-Hans-CN,zh-Hans;q=0.8,en-US;q=0.5,en;q=0.3","User-Agent: Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; WOW64; Trident/6.0)",'CLIENT-IP:'.$ip,'X-FORWARDED-FOR:'.$ip); 
  28.   $ch = curl_init(); 
  29.   curl_setopt($ch, CURLOPT_URL, $url); 
  30.   curl_setopt($ch, CURLOPT_HEADER, $v); 
  31.   curl_setopt($ch, CURLOPT_HTTPHEADER, $header); 
  32.   $ifpost && curl_setopt($ch, CURLOPT_POST, $ifpost); 
  33.   $ifpost && curl_setopt($ch, CURLOPT_POSTFIELDS, $datafields); 
  34.   curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); 
  35.   curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true); 
  36.   $cookiefile && curl_setopt($ch, CURLOPT_COOKIEFILE, $cookiefile); 
  37.   $cookiefile && curl_setopt($ch, CURLOPT_COOKIEJAR, $cookiefile); 
  38.   curl_setopt($ch,CURLOPT_TIMEOUT,60); //允许执行的最长秒数 
  39.   curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); 
  40.   curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); 
  41.   $ok = curl_exec($ch); 
  42.   curl_close($ch); 
  43.   unset($ch); 
  44.   return $ok
  45. }

Tags: curl伪造浏览器

分享到: