我无法使用以下代码用代码交换令牌:
extract($_GET);
$url=urlencode('http://'.DOMAIN.'/admin/');
$app_id=FB_APPID;
$fb_token=FB_TOKEN;
$secret=FB_SECRET;
if(SEND_NEWS_TO_FB){
if($code=='none'){
$state=rand(100000000,9999999999999999999);
$_SESSION['state']=$state;
$script="
<script type='text/javascript'>
var scope=encodeURI('publish_stream,user_status');
var app_id=$app_id;
var state=$state;
var url=$js_url;
window.location.href='https://www.facebook.com/dialog/oauth? client_id='+app_id+'&redirect_uri='+url+'&scope='+scope+'&state='+state;
</script>";
echo $script;
}
if($code!='none' && $_SESSION['state']==$state && $_SESSION['fb_token']!=1){
$_SESSION['fb_token']=1;
$token_url="https://graph.facebook.com/oauth/access_token?"
."client_id=" .$app_id
."&redirect_uri=" .$url
."&client_secret=" .$secret
."&code=" .$code;
$response = file_get_contents($token_url);
$params = null;
parse_str($response, $params);
$token=$params['access_token'];
$qry="UPDATE `settings` SET `FB_token`='$token'";
$result=mysql_query($qry);
}
将返回的$token_url放在我的浏览器中会给我一个包含令牌和到期日的页面。运行脚本会返回一条非常模糊的"对不起,出现问题"消息。我看到的几乎所有出现问题的线程都是由于重定向uri的差异造成的,但登录和令牌请求都从完全相同的地方获取uri。
app_id值和'&redirect_url'。仅供参考,你的浏览器(至少chrome(会自动对空白进行url编码,这就是为什么url在浏览器中工作良好的原因。我仍然不确定空间是如何存在的,但urlencode((暂时修复了它。