curl模拟请求、登陆以及带验证码登陆

这段PHP代码展示了如何使用curl模拟GET和POST请求,包括处理HTTPS、设置User-Agent、处理编码以及模拟登录过程。代码中包含了一个模拟登录的示例,涉及到登录前的验证码获取和用户手动输入验证码的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

[php]  view plain  copy
  1. header('content-type:text/html;charset=utf-8');    
  2. function curlPost($url,$data,$method){    
  3.     $ch = curl_init();   //1.初始化    
  4.     curl_setopt($ch, CURLOPT_URL, $url); //2.请求地址    
  5.     curl_setopt($ch, CURLOPT_CUSTOMREQUEST, $method);//3.请求方式    
  6.     //4.参数如下    
  7.     curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);//https    
  8.     curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);    
  9.     curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (compatible; MSIE 5.01; Windows NT 5.0)');//模拟浏览器    
  10.     curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);    
  11.     curl_setopt($ch, CURLOPT_AUTOREFERER, 1);    
  12.         curl_setopt($ch, CURLOPT_HTTPHEADER,array('Accept-Encoding: gzip, deflate'));//gzip解压内容    
  13.         curl_setopt($ch, CURLOPT_ENCODING, 'gzip,deflate');    
  14.         
  15.     if($method=="POST"){//5.post方式的时候添加数据    
  16.         curl_setopt($ch, CURLOPT_POSTFIELDS, $data);    
  17.     }    
  18.     curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);    
  19.     $tmpInfo = curl_exec($ch);//6.执行    
  20.     
  21.     if (curl_errno($ch)) {//7.如果出错    
  22.         return curl_error($ch);    
  23.     }    
  24.     curl_close($ch);//8.关闭    
  25.     return $tmpInfo;    
  26. }    
  27. $data=array('name' => '1234');    
  28. $url="http://www.sohu.com/";    
  29.     
  30. $method="GET";  //post或者get  
  31. $file=curlPost($url,$data,$method);    
  32. $file=mb_convert_encoding($file,'UTF-8','GBK');    
  33. echo $file;    

以下是模拟登陆的代码

[php]  view plain  copy
  1. <?php    
  2.     $cookie_file = tempnam('./temp','cookie');    
  3.     function weixinPost($url,$data,$method,$setcooke=false,$cookie_file=false){    
  4.         $ch = curl_init();   //1.初始化    
  5.         curl_setopt($ch, CURLOPT_URL, $url); //2.请求地址    
  6.         curl_setopt($ch, CURLOPT_CUSTOMREQUEST, $method);//3.请求方式    
  7.         //4.参数如下        
  8.         curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);    
  9.         curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);    
  10.         curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (compatible; MSIE 5.01; Windows NT 5.0)');    
  11.         curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);    
  12.         curl_setopt($ch, CURLOPT_AUTOREFERER, 1);    
  13.             
  14.         if($method=="POST"){//5.post方式的时候添加数据       
  15.             curl_setopt($ch, CURLOPT_POSTFIELDS, $data);    
  16.         }    
  17.         if($setcooke==true){    
  18.             curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie_file);    
  19.         }else{    
  20.             curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie_file);    
  21.         }    
  22.         curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);    
  23.         $tmpInfo = curl_exec($ch);//6.执行    
  24.     
  25.         if (curl_errno($ch)) {//7.如果出错    
  26.             return curl_error($ch);    
  27.         }    
  28.         curl_close($ch);//8.关闭    
  29.         return $tmpInfo;    
  30.     }    
  31.     $data=array('username' => '***','password'=>'***');    
  32.     $url="http://www.xinxinj.com/login.php";    
  33.     $method="POST";    
  34.     $file=weixinPost($url,$data,$method,true,$cookie_file);    
  35.     echo $file;    
  36.             
  37.     $url="http://www.xinxinj.com/admin.php";    
  38.     $method="GET";    
  39.     $file=weixinPost($url,$data,$method,false,$cookie_file);    
  40.     echo $file;    
  41.             
  42. ?>    

网上的很多模拟登录程序,大都是通过服务程序apache之类的运行,获取到验证码之后显示在网页上,然后填上再POST出去

 

本文提供了一个程序实例,思路就是获取到验证码之后把验证码存储为一个图片,然后程序休眠20秒,在20秒之后由用户手动查看图片,并把验证码填写到code.txt文件中,20秒休眠完成后,程序会读code.txt的验证码,这样再带着验证码进行登录操作。具体代码如下:


[php]  view plain  copy
  1. /** 
  2.  * 模拟登录 
  3.  */  
  4.    
  5. //初始化变量  
  6. $cookie_file = "tmp.cookie";  
  7. $login_url = "http://xxx.com/logon.php";  
  8. $verify_code_url = "http://xxx.com/verifyCode.php";  
  9.    
  10. echo "正在获取COOKIE...\n";  
  11. $curlj = curl_init();  
  12. $timeout = 5;  
  13. curl_setopt($curl, CURLOPT_URL, $login_url);  
  14. curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);  
  15. curl_setopt($curl, CURLOPT_CONNECTTIMEOUT, $timeout);  
  16. curl_setopt($curl,CURLOPT_COOKIEJAR,$cookie_file); //获取COOKIE并存储  
  17. $contents = curl_exec($curl);  
  18. curl_close($curl);  
  19.    
  20. echo "COOKIE获取完成,正在取验证码...\n";  
  21. //取出验证码  
  22. $curl = curl_init();  
  23. curl_setopt($curl, CURLOPT_URL, $verify_code_url);  
  24. curl_setopt($curl, CURLOPT_COOKIEFILE, $cookie_file);  
  25. curl_setopt($curl, CURLOPT_HEADER, 0);  
  26. curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);  
  27. $img = curl_exec($curl);  
  28. curl_close($curl);  
  29.    
  30. $fp = fopen("verifyCode.jpg","w");  
  31. fwrite($fp,$img);  
  32. fclose($fp);  
  33. echo "验证码取出完成,正在休眠,20秒内请把验证码填入code.txt并保存\n";  
  34. //停止运行20秒  
  35. sleep(20);  
  36.    
  37. echo "休眠完成,开始取验证码...\n";  
  38. $code = file_get_contents("code.txt");  
  39. echo "验证码成功取出:$code\n";  
  40. echo "正在准备模拟登录...\n";  
  41.    
  42. $post = "username=maben&pwd=hahahaha&verifycode=$code";  
  43. $curl = curl_init();  
  44. curl_setopt($curl, CURLOPT_URL, $url);  
  45. curl_setopt($curl, CURLOPT_HEADER, false);  
  46. curl_setopt($curl, CURLOPT_RETURNTRANSFER,1);  
  47. curl_setopt($curl, CURLOPT_POSTFIELDS, $post);  
  48. curl_setopt($curl, CURLOPT_COOKIEFILE, $cookie_file);  
  49. $result=curl_exec($curl);  
  50. curl_close($curl);  
  51.    
  52. //这一块根据自己抓包获取到的网站上的数据来做判断  
  53. if(substr_count($result,"登录成功")){  
  54.  echo "登录成功\n";  
  55. }else{  
  56.  echo "登录失败\n";  
  57.  exit;  
  58. }  
  59.    
  60. //OK,开始做你想做的事吧。。。。。  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值