0

当我尝试在 Kohana 中进行 Facebook 身份验证时遇到问题。

我要做的是:

在 kohana 我有一个名为 loginview.php 的视图文件,我在其中嵌入了这段代码

href="https://www.facebook.com/dialog/oauth?client_id=341106515944015"&redirect_uri=http://verana.ge/fbauth/&scope=user_about_me&state=veranalast">

在控制器文件夹中,我有一个名为 fbauth.php 的控制器,其中有这段代码

 public function action_index()
{

   $app_id = "341106515944015";
   $app_secret = "79f547b92f34f886cc8d51ca1a5d33e0";
   $my_url = "http://verana.ge/";

  // session_start(); <!-- commented because in Kohana the Session is already started -->

   $code = $_REQUEST["code"];

   if(empty($code)) {
   $_SESSION['state'] = md5(uniqid(rand(), TRUE)); //CSRF protection
         $dialog_url = "https://www.facebook.com/dialog/oauth?client_id=" 
     . $app_id . "&redirect_uri=" . urlencode($my_url) . "&state="
     . $_SESSION['state'];
   echo("<script> top.location.href='" . $dialog_url . "'</script>");
    }

if($_REQUEST["state"] = 'veranalast') {
   $token_url = "https://graph.facebook.com/oauth/access_token?"
   . "client_id=" . $app_id . "&redirect_uri=" . urlencode($my_url)
   . "&client_secret=" . $app_secret . "&code=" . $code;


   $response = file_get_contents($token_url);

   $params = null;

   parse_str($response, $params);


   $graph_url = "https://graph.facebook.com/me?access_token=" 
             . $params['access_token'];

   $user = json_decode(file_get_contents($graph_url));
           echo("Hello " . $user->name);
}
else {
   echo("The state does not match. You may be a victim of CSRF.");
}


}   

但是当我点击 facebook 链接并尝试连接时,我收到以下错误消息

  ErrorException [ Warning ]: file_get_contents(https://graph.facebook.com/oauth/access_token?client_id=341106515944015&redirect_uri=http%3A%2F%2Fverana.ge%2F&client_secret=79f547b92f34f886cc8d51ca1a5d33e0&code=AQB9jQDcWXNVhPoxhOH-GyJ_0P0UQD9y5wfFy8cfP48TxvlX0VnycEWSpTOC0NWXTyCfssTUHCwFjmZdySy74zor_AQGvtzE5YCkB3asMBhWiiAJhesbFa_GrQIzT7UWiNrbl73CmVz5hell-shwrnavUviuDvpMqg6jCbMBHa6nb39xvidf-P5KOe4wlyR9TG8) [function.文件获取内容]:打开流失败:HTTP 请求失败!HTTP/1.0 400 错误 APPPATH/classes/controller/fbauth.php [32]
27 $token_url = "https://graph.facebook.com/oauth/access_token?"
28 . “client_id=”。$app_id 。“&redirect_uri=”。urlencode($my_url)
29. “&client_secret=”。$app_secret 。“&代码=”。$代码;
30
31             
32 $response = file_get_contents($token_url);
33             
34 $参数=空;
35                         
36 parse_str($response, $params);
37

同样为了仔细检查,我在 Kohana 之外创建了这个函数,它没有问题。

我所做的是在 Kohana 之外我创建了由 index.php 命名的文件,我在其中放置了 html 一个 Facebook 身份验证的标签,接下来我创建了由 testauth.php 命名的文件,我在其中放入了与我放入 fbauth.php 相同的代码和正如我所说,它没有问题。

可能在哪里有简单的方法来解决它,但我不知道。请告诉我如何解决它。

任何想法?

先感谢您

4

1 回答 1

0

你试过打开https://graph.facebook.com/oauth/access_token?client_id=341106515944015&redirect_uri=http%3A%2F%2Fverana.ge%2F&client_secret=79f547b92f34f886cc8d51ca1a5d33e0&code=AQB9jQDcWXNVhPoxhOH-GyJ_0P0UQD9y5wfFy8cfP48TxvlX0VnycEWSpTOC0NWXTyCfssTUHCwFjmZdySy74zor_AQGvtzE5YCkB3asMBhWiiAJhesbFa_GrQIzT7UWiNrbl73CmVz5hell-shwrnavUviuDvpMqg6jCbMBHa6nb39xvidf-P5KOe4wlyR9TG8吗?它会产生 400 HTTP 错误。一切都好。

于 2012-04-26T09:49:19.723 回答