4
class Example extends CI_Controller {

    function __construct()
    {
        parent::__construct();
    }

    function index()
    {

        $this->load->library('facebooklib');

        $user = $this->facebooklib->getUser();

        if ($user) {
            try {
                $data['user_profile'] = $this->facebooklib->api('/me');
            } catch (FacebookApiException $e) {
                $user = null;
            }
        }

        var_dump($_REQUEST);

        if ($user) {
            $data['logout_url'] = $this->facebooklib->getLogoutUrl();
        } else {
            $data['login_url'] = $this->facebooklib->getLoginUrl();
        }

        $this->load->view('view',$data);
    }
}

单击登录链接后,我被带到 Facebook 权限页面,我接受,然后返回到没有数据的同一页面。

array(3) {
  ["/example"]=>
  string(0) ""
  ["PHPSESSID"]=>
  string(32) "33a446883d4fb1877fb6dcff6d70799a"
  ["ci_session"]=>
  string(311) "a:4:{s:10:"session_id";s:32:"d8bb3926550e3ec1b9d075b456708e9b";s:10:"ip_address";s:9:"127.0.0.1";s:10:"user_agent";s:120:"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_6_8) AppleWebKit/535.19 (KHTML, like Gecko) Chrome/18.0.1025.168 Safari/535.19";s:13:"last_activity";i:1336011855;}c874fb95984396f04ab6cc17217102d7"
}

我的 $_REQUEST 转储并没有真正显示 signed_request,这是一个问题。

4

3 回答 3

5

尽管有很多反对意见,但我还是找到了解决这个在 Facebook PHP-SDK 中使用 CodeIgniter 发现的非常严重 BUG 的方法。

所以这是在 CI 论坛中找到的解决方案:http: //codeigniter.com/forums/viewthread/202370/#986781

    // Stop cache
    $this->ci->output->set_header("Cache-Control: private, no-store, no-cache, must-revalidate, post-check=0, pre-check=0");
    $this->ci->output->set_header("Pragma: no-cache");

    // IE Fix
    if(strpos($this->ci->agent->agent_string(), 'MSIE') !== FALSE) {
        $this->ci->output->set_header('p3p: CP="ALL DSP COR PSAa PSDa OUR NOR ONL UNI COM NAV"');
    }

    // Repopulate _REQUEST ... Facebook needs it.
    $request_uri = $_SERVER['REQUEST_URI'];
    $request_uri = explode('?',$request_uri);
    if(count($request_uri) > 1) {
        parse_str($request_uri[1], $_REQUEST);
    }

出于某种原因,新的 PHP SDK 没有通过 CodeIgniter 传递 $_REQUEST。缓存也存在问题,IE 没有正确的标头。

所以这会从 $_SERVER['REQUEST_URI'] 构建 $_REQUEST,然后正确地通过 Facebook 类并成功返回正确的数据。

于 2012-05-03T06:56:57.230 回答
0

使用此说明可能会有所帮助

$signed_request = isset($_REQUEST['signed_request']) ? $_REQUEST['signed_request'] : $this->modelfacebook->signRequest();
于 2012-05-03T05:25:45.407 回答
0

根据这篇文章中的一个答案,出于安全原因,CodeIgniter会清除$_REQUEST 变量。我认为它与 Codeigniter Manual here中描述的自动输入过滤有关,但也没有具体提及。我不确定是否设置

 $config['global_xss_filtering'] = TRUE;

在 config.php 中是否影响它(我将它设置为 TRUE 在我的),但至少现在你/我们知道为什么 $_REQUEST 变量不可用。

有趣的是,我的 CIApplication/libraries/ 文件夹中有 FB SDK 库,它似乎可以很好地访问 $_REQUEST 变量,只是不在我的视图或控制器中。

当我看到这篇文章时,我正在寻找同一个问题的答案——你的问题也是一个完全有效的好问题!

干杯马特

于 2012-09-16T06:32:16.283 回答