users_model に isLoggedin() という名前の静的関数があり、作成したライブラリが必要です。読み込めません!これは、SessionsHelper.php という名前のライブラリ フォルダーにあり、その中に SessionsHelper クラスがあります (当然のことですが)。静的関数にロードしようとしましたが、静的関数で$this->load->library('SessionsHelper')
$this を使用できないことがわかりました。次にrequire_once '../libraries/SessionsHelper.php'
、機能しないを使用してロードしようとしましたが、オートローダーも機能しませんでした....ここに関数があります。
public static function isLoggedin() {
if (SessionsHelper::get('id') != '' && SessionsHelper::get('id') >= 0) { // TODO add logic to differentiate between user/admin
return true;
}
return false;
}
ライブラリを使用できるようにする必要があります。どんな助けでも大歓迎です!
編集:コントローラーは次のとおりです。
class Users extends CI_Controller{
public function login(){
$this->load->model('users_model');
if($this->users_model->isLoggedin()){
redirect($this->config->base_url);
}
$data['info'] = $this->users_model->login('slavigne@uark.edu', 'abcdefg');
$this->load->view('templates/header');
$this->load->view('users/login', $data);
$this->load->view('templates/footer');
}
public function logout(){
$this->load->library('SessionHelper');
SessionsHelper::destroy();
}
}
モデルは次のとおりです。
class users_model extends CI_Model{
public function users_model(){
parent::__construct();
}
public static function hash($password, $salt) {
//this code works no problem! but it's private you know?
}
public static function isLoggedin() {
$CI =& get_instance();
$CI->load->library('SessionsHelper');
if (SessionsHelper::get('id') != '' && SessionsHelper::get('id') >= 0) { // TODO add logic to differentiate between user/admin
return true;
}
return false;
}
public function login($email, $password){
$this->load->library('SessionHelper');
$this->load->database();
$query = $this->db->get_where('users', array('email' => $email));
$result = $query->result();
if($result[0]->password == $this->hash($password, $result[0]->salt)){
//error_log("Pass matched!");
SessionHelper::set('id', $result[0]->id);
}
return $result[0];
}
}
ライブラリは application/libraries/Sessinshelper.php にあります:
class Sessionshelper {
public function __construct() {
}
public static function start() {
if (!session_id()) {
session_start();
}
}
public static function set($fld, $val) {
self::start();
$_SESSION[$fld] = $val;
}
public static function un_set($fld) {
self::start();
unset($_SESSION[$fld]);
}
public static function destroy() {
if (session_id() != "" || isset($_COOKIE[session_name()])) {
$params = session_get_cookie_params();
setcookie(session_name(), '', time() - 42000, $params["path"], $params["domain"], $params["secure"], $params["httponly"]);
}
session_unset();
$_SESSION = array();
session_destroy();
}
public static function get($fld) {
self::start();
if (isset($_SESSION[$fld])) {
return $_SESSION[$fld];
}
return FALSE;
}
}