首页 >后端开发 >php教程 > 正文

PHP之curl伪装来源信息

原创2017-12-23 16:08:3101518
在有些时候,我们需要使用CURL来模拟请求完成一些事情。但现实总是和理想有些差距,对方服务器可能队请求来源信息做了一些限制,这个时候该如何处理呢?本文就将告诉你如何让curl伪装来源信息,来骗过服务器的来源信息限制。

[one.php]

<?php
$post_data = array (
"user" => "admin",
"pwd" => "123456"
);
$header_ip = array(
  'CLIENT-IP:8.8.8.8',
  'X-FORWARDED-FOR:8.8.8.8',
);
$referer='http://www.liangshao.com';
$ch = curl_init();
curl_setopt ($ch, CURLOPT_URL, 'http://localhost/curl/two.PHP');
//伪造来源referer
curl_setopt ($ch,CURLOPT_REFERER,$referer);
//伪造来源ip
curl_setopt($ch, CURLOPT_HTTPHEADER, $header_ip);
//提交post传参
curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data);
//加上这个表示执行curl_exec是把输出做为返回值,不会输出到浏览器
curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);
$out_put=curl_exec ($ch);
curl_close ($ch);
echo $out_put;

[two.php]

<?php
//请求来源referer
echo '[HTTP_REFERER]<br>';
echo $_SERVER['HTTP_REFERER'];
 //请求来源ip
 //[注]此处的IP打印顺序是目前很多开源系统的IP获取顺序 
 echo '<hr>[IP]<br>';
 echo $_SERVER['HTTP_CLIENT_IP'];
 echo '<br>';
 echo $_SERVER['HTTP_X_FORWARDED_FOR'];
 echo '<br>';
 echo $_SERVER['REMOTE_ADDR'];
 //POST数据
 echo '<hr>[POST]<br><pre>';
 var_dump($_POST);
 echo '</pre>';

相关阅读;

php CURL获取cookies模拟登录的方法代码实例

php curl错误排查的方法详解

PHP curl模拟登录带验证码的网站

以上就是PHP之curl伪装来源信息的详细内容,更多请关注php中文网其它相关文章!

php中文网最新课程二维码

声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理

  • 相关标签:curl 来源信息 php
  • 相关文章

    相关视频


    网友评论

    文明上网理性发言,请遵守 新闻评论服务协议

    我要评论
  • 专题推荐

    推荐视频教程
  • javascript初级视频教程javascript初级视频教程
  • jquery 基础视频教程jquery 基础视频教程
  • 视频教程分类