CodeIgniter とhttps://github.com/chriskacerguis/codeigniter-restserverの RestServer 実装を使用して API を構築しています。
「セッション」認証モードを使用したいので、これを config/rest.php に設定します。
$config['rest_auth'] = 'session';
$config['auth_source'] = 'userdata';
config/config.php で:
$config['sess_driver'] = 'database';
$config['sess_cookie_name'] = 'ci_session';
$config['sess_expiration'] = 7200;
$config['sess_save_path'] = 'ci_sessions';
$config['sess_match_ip'] = FALSE;
$config['sess_time_to_update'] = 300;
$config['sess_regenerate_destroy'] = FALSE;
次のコードを持つコントローラーAuthがあります。
class Auth extends My_Controller
{
public function __Construct(){
parent::__construct();
}
public function index(){
$user = array(
"id" => "1",
"first_name" => "First",
"insertion" => "",
"last_name" => "Last"
);
$this->session->userdata = $user;
pr($this->session->userdata);
}
}
セッションはデータベースに保存され、$user からのデータが含まれます。pr はデータをエコーします (pr はフックで定義され、print_r($data) を実行します)。
しかし..コントローラーウィッチを実行すると、REST_Controller が拡張され、常に {"status":false,"error":"Unauthorized"} エラーが発生します。
私はたくさん検索しましたが、これに対する解決策を見つけることができません (または、誰も「セッション」認証方法を使用していませんか?)、おそらく誰かが解決策を知っていますか?
ありがとう!
編集:私の API 関数の 1 つのコントローラー:
class Club extends REST_Controller
{
function __construct()
{
parent::__construct();
$this->load->model('Club_model');
}
public function index_get(){
if(!$this->get('id')){
$clubs = $this->Club_model->get_all_clubs();
}else{
$clubs = $this->Club_model->get_club($this->get('id'));
}
if($clubs){
$this->response($clubs, 200);
}else{
$this->response(null, 404);
}
}
編集 2: autoload.php config/autoload.php に「セッション」を追加しました
$autoload['libraries'] = array('database','session');