2011-11-10 147 views
-3

我想要报废Facebook页面(https://www.facebook.com/pages/PTSD/455847705426) 我发现这个脚本登录到Facebook。Facebook页面抓取

<?php 
$EMAIL = "[email protected]"; 
$PASSWORD = "facebookPassword"; 

function cURL($url, $header=NULL, $cookie=NULL, $p=NULL) 
{ 
$ch = curl_init(); 
curl_setopt($ch, CURLOPT_HEADER, $header); 
curl_setopt($ch, CURLOPT_NOBODY, $header); 
curl_setopt($ch, CURLOPT_URL, $url); 
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0); 
curl_setopt($ch, CURLOPT_COOKIE, $cookie); 
curl_setopt($ch, CURLOPT_USERAGENT, $_SERVER['HTTP_USER_AGENT']); 
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0); 
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1); 

if ($p) { 
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST"); 
curl_setopt($ch, CURLOPT_POST, 1); 
curl_setopt($ch, CURLOPT_POSTFIELDS, $p); 
} 
$result = curl_exec($ch); 

if ($result) { 
return $result; 
} else { 
return curl_error($ch); 
} 
curl_close($ch); 
} 

$a = cURL("https://login.facebook.com/login.php?login_attempt=1",true,null,"email=$EMAIL&pass=$PASSWORD"); 
preg_match('%Set-Cookie: ([^;]+);%',$a,$b); 
$c = cURL("https://login.facebook.com/login.php?login_attempt=1",true,$b[1],"email=$EMAIL&pass=$PASSWORD"); 
preg_match_all('%Set-Cookie: ([^;]+);%',$c,$d); 
for($i=0;$i<count($d[0]);$i++) 
$cookie.=$d[1][$i].";"; 

/* 
NOW TO JUST OPEN ANOTHER URL EDIT THE FIRST ARGUMENT OF THE FOLLOWING FUNCTION. 
TO SEND SOME DATA EDIT THE LAST ARGUMENT. 
*/ 
$page_html = cURL("https://www.facebook.com/pages/PTSD/455847705426",null,$cookie,null); 


?> 

现在变量$ page_html只有几个帖子,而且他们是在非常复杂的代码 我的问题是

  1. 我怎么能得到的所有帖子。
  2. 是否有其他一些方法可以让我获得完整清晰的数据。
  3. 是否有某种方式可以让所有帖子以json格式。

请告诉我是否有关于此的一些有用的教程或文章。

问候

+2

从[Facebook的条款和条件](https://www.facebook.com/terms.php):您不会收集用户的内容或信息,或以其他方式访问Facebook,使用自动方式(如收集机器人,机器人,蜘蛛或刮板)未经我们许可。 – Quentin

+0

不会帮你打破Facebook的服务条款。 – bkaid

回答

2

花一些时间阅读developer documentation。您可以通过设置应用程序将所有帖子作为JSON对象从页面获取,然后使用页面访问令牌查询图形api。