我的facebook应用程序授权有问题。当我在我的本地Web服务器上正常运行我的应用程序时,过程如下:
**Get facebook user->If user is not logged on -> Redirect user on facebook login page**
**Get facebook user->If user is logged on -> Redirect user to authorize my facebook application->everything goes right without problems**
当我使用iframe在facebook上托管我的应用程序时,第二个进程无效(用户永远不会显示授权窗口),并且我得到以下异常:
Error validating access token: User xxxxxxx has not authorized application xxxxxxx.
我正在使用CodeIgniter PHP框架,这是我的PHP代码:
$this->load->library('facebook');
$user = null;
$user_profile = null;
$user = $this->facebook->getUser();
if ($user) {
try {
// Proceed knowing you have a logged in user who's authenticated.
$access_token = $this->facebook->getAccessToken();
$user_profile = $this->facebook->api($user);
}
catch (FacebookApiException $e) {
show_error(print_r($e, TRUE), 500);
}
}
else{
$data = array(
'redirect_uri' => 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx','scope'=>'email');
$access_token = $this->facebook->getAccessToken();
redirect($this->facebook->getLoginUrl($data));
}
$data['facebook']=$user_profile;
$this->load->view('templates/header');
$this->load->view('pages/prijavaKlasicnoFacebook', $data);
$this->load->view('templates/footer');
}
答案 0 :(得分:0)
您无法在iframe中加载OAuth对话框 - 安全原因。
您必须将其加载到最顶层的窗口实例中 - 因此没有服务器端重定向,而是使用top.location.href = "…";
让您的脚本在其他空文档中输出此JS片段(包括正确的登录URL)。
答案 1 :(得分:0)
您还应在您的范围内提供“阅读流”和“发布数据”。