我正在使用CakePHP2.4和facebook PHP SDK3.2.3创建登录表单,它有两个选项:本地登录并使用facebook登录。我一直指的是 如何将facebook SDK login与cakephp2集成。x? 关于如何创建登录操作和查看facebook登录。

现在我有工作本地登录,当我按到facebook登录时,我被重定向到facebook并再次回到我的插件用户的登录操作。但是我没有得到任何回应 $_GET['code']$this->request->query['code'].

这是我的登录操作:

    public function login() { 
        if ($this->Auth->user()) {
            $this->Session->setFlash(__('You are already registered and logged in!'),          'flash_info');
        $this->redirect('/');
    }
    if ($this->request->is('post')) {
        if ($_SERVER['HTTP_HOST'] == Configure::read('webakis.touchscreen_host')) {
            $this->request->data['User']['username'] = $this->request->data['User']['name'] . ' ' . $this->request->data['User']['surname'];
        }

        if ($this->Auth->login()) {
            $this->User->id = $this->Auth->user('id');
            $this->User->saveField('last_login', date('Y-m-d H:i:s'));

            if ($this->here == $this->Auth->loginRedirect) {
                $this->Auth->loginRedirect = '/';
            }
            $this->Session->setFlash(sprintf(__('%s you have successfully logged in'), $this->Auth->user('name')), 'flash_success');
            if (!empty($this->request->data)) {
                $data = $this->request->data[$this->modelClass];
                $this->_setCookie(array('name' => 'AKIS'), 'User');
            }

            if (empty($data['return_to'])) {
                $data['return_to'] = null;
            }

            $this->redirect($this->Auth->redirect($data['return_to']));
        } else {
            $this->Session->setFlash(__('Invalid e-mail / password combination.  Please try again'), 'flash_error');
        }
    }
    // When facebook login is used, facebook always returns $_GET['code'].
    if($this->request->query('code')){ //Execution doesn't get in here

        Debugger::log($this->request->query);

        // User login successful
        $fb_user = $this->Facebook->getUser();          # Returns facebook user_id
        if ($fb_user){

            Debugger::log($fb_user);
            $fb_user = $this->Facebook->api('/me');     # Returns user information

            // We will varify if a local user exists first
            $local_user = $this->User->find('first', array(
                'conditions' => array('email' => $fb_user['email'])
            ));

            // If exists, we will log them in
            if ($local_user){
                $this->Auth->login($local_user['User']);            # Manual Login
                $this->redirect($this->Auth->redirectUrl());
            } 

            // Otherwise we ll add a new user (Registration)
            else {
                $data['User'] = array(
                    'username'      => $fb_user['email'],                               # Normally Unique
                    'password'      => AuthComponent::password(uniqid(md5(mt_rand()))), # Set random password
                    'role'          => 'registered'
                );

                // You should change this part to include data validation
                $this->User->save($data, array('validate' => false));

                $this->redirect('/');
                // After registration we will redirect them back here so they will be logged in
                //$this->redirect(Router::url('/users/login?code=true', true));
            }
        }   
    }
    if (isset($this->request->params['named']['return_to'])) {
        $this->set('return_to', urldecode($this->request->params['named']['return_to']));
    } else {
        $this->set('return_to', false);
    }
    $allowRegistration = Configure::read('Users.allowRegistration');
    $this->set('allowRegistration', (is_null($allowRegistration) ? true : $allowRegistration));
    Configure::write('keyboard', 1);
}

在这里没有得到回应,我无法处理我的facebook登录逻辑。

这些是我得到的回复,然后facebook将我重定向回登录页面:enter image description here

两个有趣的请求(显示Url参数和位置):

GET oauth?....

client_id=671394586273323
ext=1406709978
hash=AeYXzQgAjCbRdY4g
redirect_uri=http://127.0.0.1.xip.io/users/users/login
ret=login
sdk=php-sdk-3.2.3
state=9d030270aa50f2e52ac4aa66a37cd0fd

Location: http://127.0.0.1.xip.io/users/users/login?code=AQC_UtjKJU8a2leJMFAB4_1qx1mh1ww0-sRWdAD5vCocfKuZPTF4iSdKYwqxQUsm9N-_1tSPGfh3LYQXbXjYeY2onVBD6gTvJ5amvRZm5ZjI1OSYoLkqgjBsdfjWSdXTigCIQLf5d180keXTCf5jRiOXi8pWi0V2UxXqVl4K9QWWq2qGfSGuXlJMr32NZqKYR0Z93LyR1EiRFJPohfo6-j0kZJrNTkljCbY16Nrq1InqQLdYwGCOSg4IrbR0auaMIWTlnUCKFCr4DT3If_5HPFEDM6ZigeUvURM-q8y-CxDrRIctSmT4Bz1UevPqR-hOMbgKGzYUplatRywzjq_-R7bt&state=9d030270aa50f2e52ac4aa66a37cd0fd#_=_

获得登录?密码。...

code=AQC_UtjKJU8a2leJMFAB4_1qx1mh1ww0-sRWdAD5vCocfKuZPTF4iSdKYwqxQUsm9N-_1tSPGfh3LYQXbXjYeY2onVBD6gTvJ5amvRZm5ZjI1OSYoLkqgjBsdfjWSdXTigCIQLf5d180keXTCf5jRiOXi8pWi0V2UxXqVl4K9QWWq2qGfSGuXlJMr32NZqKYR0Z93LyR1EiRFJPohfo6-j0kZJrNTkljCbY16Nrq1InqQLdYwGCOSg4IrbR0auaMIWTlnUCKFCr4DT3If_5HPFEDM6ZigeUvURM-q8y-CxDrRIctSmT4Bz1UevPqR-hOMbgKGzYUplatRywzjq_-R7bt
state=9d030270aa50f2e52ac4aa66a37cd0fd

Location:   http://127.0.0.1.xip.io/eng/login

我觉得很奇怪,代码不是第一个请求中的URL参数,而是在URL中,第二个响应显示相反的情况。

好吧,这可能是路由问题。

    $this->set('fb_login_url', $this->Facebook->getLoginUrl(array('redirect_uri' => Router::url(array('plugin'=> 'users', 'controller' => 'users', 'action' => 'login'), true)))); 

Router::url()返回: http://127.0.0.1.xip.io/users/users/login

我的路由器连接:

    Router::connect('/:language/login', array('plugin' => 'users', 'controller' => 'users', 'action' => 'login'), array('language' => '[a-z]{3}'));
    Router::connect('/:language/logout', array('plugin' => 'users', 'controller' => 'users', 'action' => 'logout'), array('language' => '[a-z]{3}'));
    Router::connect('/:language/register', array('plugin' => 'users', 'controller' => 'users', 'action' => 'add'), array('language' => '[a-z]{3}'));
    Router::connect('/:language/users', array('plugin' => 'users', 'controller' => 'users'), array('language' => '[a-z]{3}'));
    Router::connect('/:language/users/index/*', array('plugin' => 'users', 'controller' => 'users'), array('language' => '[a-z]{3}'));
    Router::connect('/:language/users/:action/*', array('plugin' => 'users', 'controller' => 'users'), array('language' => '[a-z]{3}'));
    Router::connect('/:language/users/users/:action/*', array('plugin' => 'users', 'controller' => 'users'), array('language' => '[a-z]{3}'));

Al这些url重定向到: http://127.0.0.1.xip.io/eng/login .这可能是问题,因为facebook SDK有不同的重定向URL,所以它重定向到 http://127.0.0.1.xip.io/users/users/login ,也有请求重定向到 http://127.0.0.1.xip.io/eng/login.此重定向后,查询参数'code'可能会丢失。

有帮助吗?

解决方案

从网络控制台和您发布的标题中可以看出,您的服务器正在进行额外的重定向,正如我的评论中已经提到的,这是查询参数丢失的地方。

看起来你传递给facebook的重定向URL是错误的,它是

http://127.0.0.1.xip.io/users/users/login

其中最有可能至少包含盈余 users (不知道这是从哪里来的,你必须自己计算),除非你使用一个名为 Users 其中包含一个名为 UsersController, ,所以也许它应该更像

http://127.0.0.1.xip.io/users/login

但是,考虑到您的服务器重定向到 /eng/login 访问时 /users/users/login, ,可能是传递给facebook的重定向URL完全错误。

因此,首先您必须弄清楚登录的实际正确URL,然后确保 Router::url() (假设您正在使用链接问题中的代码)实际上生成了确切的URL。

更新资料

从查看您更新的问题,我不明白为什么这些路由中的任何一个应该导致重定向,它们不是重定向路由,而只是路由。实际的重定向将源于其他地方。

万一重定向到 /eng/login 是acutally缩进的,那么你必须确保你将该URL作为重定向URL传递到facebook,这是正确的调用 Router::url()language 密钥集,以便它将匹配您的第一条路线

Router::url(
    array(
        'plugin' => 'users',
        'controller' => 'users',
        'action' => 'login',
        'language' => 'eng'
    ),
    true
);

或使用 persist 在您的路线选项,以便调用 Router::url() 如果当前URL包含语言元素,则没有语言键将匹配您的路线,如下所示

Router::connect(
    '/:language/login',
    array('plugin' => 'users', 'controller' => 'users', 'action' => 'login'),
    array('language' => '[a-z]{3}', 'persist' => array('language'))
);
// ...

// connect all default routes with a persistent language prefix
Router::connect(
    '/:language/:controller/',
    array('action' => 'index'),
    array('language' => '[a-z]{3}', 'persist' => array('language'))
);
Router::connect(
    '/:language/:controller/:action/*',
    array(),
    array('language' => '[a-z]{3}', 'persist' => array('language'))
);

或者,作为最后一个选项,将查询字符串包含在重定向到 /eng/login

array(/* other route params */, '?' => $this->request->query)

其他提示

由于路由器问题,我在 $this->Facebook->getLoginUrl()'redirect_uri' => Router::url('/', true).Configure::read('Config.language').'/login' ,因为它决心 http://127.0.0.1.xip.io/eng/login .

现在我明白了 $this->request->query('code') param,所以我的代码现在应该工作。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top