Facebookを使用してユーザーを認証するために、CodeIgniterにphilsturgeonのOATH2スパークを使用しようとしています。Spark をインストールして、彼が github で提供している使用例を試してみました。
次のコードでは、id と secret のみを変更しました。
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
class Auth extends CI_Controller
{
public function session($provider)
{
$this->load->helper('url_helper');
$this->load->spark('oauth2-0.4.0');
$provider = $this->oauth2->provider($provider, array(
'id' => 'My_ID',
'secret' => 'MY_Secret',
));
if ( ! $this->input->get('code'))
{
// By sending no options it'll come back here
$provider->authorize();
}
else
{
// Howzit?
try
{
$token = $provider->access($_GET['code']);
$user = $provider->get_user_info($token);
// Here you should use this information to A) look for a user B) help a new user sign up with existing data.
// If you store it all in a cookie and redirect to a registration page this is crazy-simple.
echo "<pre>Tokens: ";
var_dump($token);
echo "\n\nUser Info: ";
var_dump($user);
}
catch (OAuth2_Exception $e)
{
show_error('That didnt work: '.$e);
}
}
}
}
しかし、私が使用してコントローラーを呼び出そうとしているとき
http://localhost/tddd27/index.php/auth/session/facebook
私は以下を取得します:
A PHP Error was encountered
Severity: Notice
Message: Undefined property: Auth::$session
Filename: libraries/Provider.php
Line Number: 117
Fatal error: Call to a member function set_userdata() on a non-object in
C:\xampp\htdocs\tddd27\sparks\oauth2-0.4.0\libraries\Provider.php の 117 行目
ライブラリに何か問題がありますか、それとも私が何か間違ったことをしていますか?