私は MVC と codeigniter を学ぼうとしており、何が間違っているのかを理解しようとしています。電子メールとパスワードを含む非常に単純なフォームでログインしようとしています。コントローラーでは、最初にフォームを含むビューを読み込みます。すべてを入力して「loginSubmit」ボタンをクリックすると、コントローラーの「login()」に移動するはずです。
メソッド「login()」でモデルをロードし、そこで「validate()」メソッドを呼び出します。何かが返されたら、コントローラーに true を返してセッションを開始し、プロファイル ページにリダイレクトします。
今の問題は、ログインするために何を与えても、常にログインメソッドでログインコントローラーを更新することです
だから私は
http://localhost/project/index.php/login/
送信を押すと、
http://localhost/project/index.php/login/login/
なぜそれはチェックをしていないのですか、何が起こっているのですか?
login_view
<?php
$loginEmail = array('placeholder' => "Email", 'name' => "loginEmail");
$loginPassword = array('placeholder' => "Wachtwoord", 'name' => "loginPassword");
$loginSubmit = array('name' => "loginSubmit", 'class' => "btn", 'value' => "Inloggen");
$loginForgot = array('name' => "loginForgot", 'class' => "link", 'value' => "Wachtwoord vergeten?");
echo form_open('login/login', array('class' => 'grid-100 formc'));
echo form_input($loginEmail);
echo form_password($loginPassword);
echo form_submit($loginSubmit);
echo form_submit($loginForgot);
?>
login_controller
<?php
Class Login extends CI_Controller{
public function __construct() {
parent::__construct();
}
function index(){
$data['content'] = 'login_view';
$this->load->view('templates/template', $data);
}
function login(){
$this->load->model('login_model');
$query = $this->login_model->validate();
if($query){
$data = array(
'username' => $this->input->post('loginEmail'),
'loggedin' => true
);
$this->session->set_userdata($data);
redirect('profile/myprofile');
}
else{
echo "not logged in";
}
}
}
?>
login_model
<?php
Class Login_model extends CI_Model{
function __construct(){
parent::__construct();
}
function validate(){
$this->db->where('email', $this->input->post('loginEmail'));
$this->db->where('password', md5($this->input->post('loginPassword')));
// I also tried with get_where, but same effect. BTW. what is the difference between where() and get_where() and what is better?
//$query = $this->db->get_where('tbl_users', array(('email', $this->input->post('loginEmail'), ('password', $this->input->post('loginPassword')));
$query = $this->db->get('tbl_users');
if($query->num_rows == 1){
return true;
}
}
}
?>