Php 代码点火器3和会话
在2.x版本的CI中,我的会话运行良好。我曾经使用默认的CI会话选项(我相信是浏览器)保存它们,但现在我决定使用数据库。我已经在配置文件中设置了表和其他所有内容。问题是我从来没有犯过任何错误。会话和加密库位于自动加载配置文件中。在我的模型中,我使用以下代码将数据放入会话:Php 代码点火器3和会话,php,codeigniter,session,codeigniter-3,Php,Codeigniter,Session,Codeigniter 3,在2.x版本的CI中,我的会话运行良好。我曾经使用默认的CI会话选项(我相信是浏览器)保存它们,但现在我决定使用数据库。我已经在配置文件中设置了表和其他所有内容。问题是我从来没有犯过任何错误。会话和加密库位于自动加载配置文件中。在我的模型中,我使用以下代码将数据放入会话: $this->session->set_userdata(array( 'email' => $email, 'is_logged_in' => 1) ); 但当我尝试使用: var_dum
$this->session->set_userdata(array(
'email' => $email,
'is_logged_in' => 1)
);
但当我尝试使用:
var_dump($this->session->userdata());
我得到以下输出:
array(1) { ["__ci_last_regenerate"]=> int(1448664996) }
未向会话添加任何内容,未显示任何错误。有人能帮忙吗
编辑:
config.php
$config['sess_driver'] = 'database';
$config['sess_cookie_name'] = 'mydomain';
$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;
autoload.php
$autoload['libraries'] = array('database', 'email', 'encryption', 'session');
我已经按照文档显示的所有说明进行了操作
编辑2:
控制器:
public function login_into_site()
{
if($this->input->post('viaAjax') == 1)
{
$this->form_validation->set_rules('email', 'Email', 'required|trim|valid_email|callback_validate_credentials');
$this->form_validation->set_rules('password', 'Password', 'required|md5|trim');
$user_url = base64_decode($this->input->post('rand'));
if ($this->form_validation->run())
{
$sulo = array();
$sulo['res'] = '1';
$sulo['address'] = $user_url;
echo json_encode($sulo);
}
else
{
$formError = array();
$formError['email'] = form_error('email');
$formError['password'] = form_error('password');
echo json_encode($formError);
}
}
else
{
echo json_encode("fail");
}
}
public function validate_credentials()
{
$this->load->model('user/model_user_auth');
$this->model_user_auth->can_log_in($message);
if($message == 1)
{
return true;
}
else if($message == 2)
{
$this->form_validation->set_message('validate_credentials','not activated');
return false;
}
else
{
$this->form_validation->set_message('validate_credentials','bad username or password');
return false;
}
}
型号:
public function can_log_in(&$message)
{
$email = $this->input->post('email');
$this->db->where('email',$email);
$this->db->where('password',md5($this->input->post('password')));
$query = $this->db->get('users');
$message = '';
if($query->num_rows() == 1)
{
$this->session->set_userdata(array(
'email' => $email,
'is_logged_in' => 1)
);
foreach ($query->result() as $row)
{
$activated = $row->activate;
$membership = $row->membership;
}
if($activated == NULL && $membership == 'a')
{
$message = 1; //success
}
else if($activated != NULL && $membership == 'a')
{
$message = 2; //not activated
}
else
{
$message = 3; // user exist but info wrong
}
}
else
{
$message = 0; // user does not exist
}
}
模型生成
$message=1代码>,因为我在控制器回调函数和控制器函数中得到返回为“TRUE”的结果,该函数记录用户在继续时没有任何错误已解决。问题是我的cookie覆盖了数据库会话。在配置文件中,如果将数据库用于会话,此行不能有值“
为了让会话使用数据库工作,该值必须为空:
$config['sess_cookie_name'] = '';
如果不为空,CI将默认为会话的Cookie。这并不意味着您不能使用Cookie。您只需通过helper加载它们,它们就可以正常工作。您创建的表,是用于CI2还是CI3?@Tpojka用于CI3。我是从您为什么提到CI2得到的?@Tpojka“我在2.x版本的CI中会话工作正常。”,用于在2中工作。3中的否不适用work@Tpojka如果可能的话,我已经添加了配置信息。我感到困惑的原因是,代码看起来正常,并没有错误,但它并没有保存会话信息。其余的代码执行得很好。即使我把$\u SESSION['email']=$email
放进去也不起作用,但如果我把SESSION\u start()放进去代码>我收到一个会话已启动的错误。请说明此信息的来源好吗?我正在使用redis会话,并将会话ID存储在一个带有名称的cookie中,一切都很好。我很想了解更多关于你上面提到的观点。
$config['sess_cookie_name'] = '';