使用Codeigniter的混合身份验证 [英] Hybrid Auth with Codeigniter

查看:163
本文介绍了使用Codeigniter的混合身份验证的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我下载了HybridAuth的codeigniter扩展程序:

I downloaded the codeigniter extension of HybridAuth here:

https://github.com/andacata/HybridIgniter

我按照使用说明进行操作。当我尝试通过任何提供商在 www.mydomainname.com/hauth/login/twitter 登录时,它会加载一个页面:

I followed instructions on its use. When I try to login via any provider at: www.mydomainname.com/hauth/login/twitter it loads a page saying:

HybridAuth
Open Source Social Sign On PHP Library. 
hybridauth.sourceforge.net/

它从来不工作。我有Twitter和Facebook的有效的API凭据,但都加载此页面,没有其他发生。非常感谢任何提示。

It never works. I have valid API credentials for Twitter and Facebook but both load this page and nothing else happens. Any tips would be greatly appreciated.

UPDATE

我的日志说: / p>

My log says:

Hybrid_Provider_Adapter::login( facebook ), redirect the user to login_start URL. -- Array
(
    [hauth_return_to] => http://www.sitename.com/hauth/login/facebook
    [hauth_token] => 6vjglu8usmsjqsi74cku8o85j3
    [hauth_time] => 1335997302
    [login_start] => http://sitename.com/hauth/endpoint?hauth.start=facebook&hauth.time=1335997302
    [login_done] => http://sitename.com/hauth/endpoint?hauth.done=facebook
)

INFO -- 127.0.0.1 -- 2012-05-03T00:21:42+02:00 -- Enter Hybrid_Auth::redirect( http://sitename.com/hauth/endpoint?hauth.start=facebook&hauth.time=1335997302, PHP )

UPDATE

这是指向控制器的链接

https://github.com/ andacata / HybridIgniter / blob / master / application / controllers / hauth.php

推荐答案

100%:

class Auth extends MX_Controller {

    public function __construct()
    {
        parent::__construct();
        $this->template->set_layout('login');

    }

    //social login
    public function social($provider)
    {
        try{
            $this->load->library('HybridAuthLib');
            $this->load->model('auth_model');
            $serviceEnabled = $this->hybridauthlib->serviceEnabled($provider);
            if ($serviceEnabled)
            {

                $this->service = $this->hybridauthlib->authenticate($provider);
                if ($this->service->isUserConnected())
                {
                    $user_profile = $this->service->getUserProfile();
                    if($this->auth_model->count_user_by_uid($user_profile->identifier) === 0)
                    {
                        $this->session->set_flashdata('message','You Dont have account.. Create one.');
                        redirect('/users/register','refresh');
                    }
                    else
                    {
                        $dump_data = $this->auth_model->get_by(array('provider_uid'=>$user_profile->identifier));
                        $user = $this->ion_auth->user($dump_data->user_id)->row();

                        $session_data = array(
                            'identity'             => $user->{$this->config->item('identity', 'ion_auth')},
                            'username'             => $user->username,
                            'email'                => $user->email,
                            'user_id'              => $user->id, //everyone likes to overwrite id so we'll use user_id
                            'old_last_login'       => $user->last_login
                        );

                        $this->ion_auth->update_last_login($user->id);

                        $this->ion_auth->clear_login_attempts($this->config->item('identity', 'ion_auth'));

                        $this->session->set_userdata($session_data);

                        if ($this->config->item('remember_users', 'ion_auth'))
                        {
                            $this->ion_auth->remember_user($user->id);
                        }

                        $this->ion_auth->trigger_events(array('post_login', 'post_login_successful'));
                        $this->ion_auth->set_message('login_successful');
                        redirect('/','refresh');
                    }
                }
                else // Cannot authenticate user
                {
                    $this->session->set_flashdata('message','Cannot authenticate user');
                    redirect('/users/auth/login/','refresh');
                }

            }
            else // This service is not enabled.
            {
                $this->session->set_flashdata('message','This providers is not enabled.');
                redirect('/users/auth/login/','refresh');
            }
        }
        catch(Exception $e)
        {
            $error = 'Unexpected error';
            switch($e->getCode())
            {
                case 0 : $error = 'Unspecified error.'; break;
                case 1 : $error = 'Hybriauth configuration error.'; break;
                case 2 : $error = 'Provider not properly configured.'; break;
                case 3 : $error = 'Unknown or disabled provider.'; break;
                case 4 : $error = 'Missing provider application credentials.'; break;
                case 5 : log_message('debug', 'controllers.HAuth.login: Authentification failed. The user has canceled the authentication or the provider refused the connection.');
                         //redirect();
                         if (isset($service))
                         {
                            $service->logout();
                         }
                         $error = 'User has cancelled the authentication or the provider refused the connection.';
                         break;
                case 6 : $error = 'User profile request failed. Most likely the user is not connected to the provider and he should to authenticate again.';
                         break;
                case 7 : $error = 'User not connected to the provider.';
                         break;
            }

            if (isset($this->service))
            {
                $this->service->logout();
            }
            log_message('error', 'controllers.HAuth.login: '.$error);
            $this->session->set_flashdata('message', $error);
            redirect('/users/auth/login/', 'refresh');          
        }       

    }

    public function endpoint()
    {
        log_message('debug', 'controllers.HAuth.endpoint called.');
        log_message('info', 'controllers.HAuth.endpoint: $_REQUEST: '.print_r($_REQUEST, TRUE));

        if ($_SERVER['REQUEST_METHOD'] === 'GET')
        {
            log_message('debug', 'controllers.HAuth.endpoint: the request method is GET, copying REQUEST array into GET array.');
            $_GET = $_REQUEST;
        }

        log_message('debug', 'controllers.HAuth.endpoint: loading the original HybridAuth endpoint script.');
        require_once ADDONPATH.'/users/third_party/hybridauth/index.php'; //ADDONPATH is my modules path
    }
}

可以发现它有用。
我使用ion_auth作为主登录系统。
auth_model是一个小模型,它检查用户是否已启用此名称的提供者,因为我想用户有相同的数据,即使他使用另一个社交网络登录..

i hope that you can find it useful. am using the ion_auth for the main login system. the auth_model is a small model which check if the user has enabled this provider with name or not, since i want the user to have the same data even if he use another social network to login with ..

这篇关于使用Codeigniter的混合身份验证的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆