<?php class Controllers_login extends CI_Controller{ public function __construct(){ parent::__construct(); $this->load->database(); $this->load->library('session'); $this->load->helper('url'); $this->load->library('form_validation'); } public function index(){ $this->load->view('views_mainpage'); } public function login(){ $this->load->view('views_login'); } public function main(){ $this->form_validation->set_rules('email','mailaddress','required'); $this->form_validation->set_rules('password','mypassword','required'); if($this->form_validation->run()==FALSE){ $this->load->view('views_login'); } else{ $email=$this->input->post('email'); $password=$this->input->post('password'); $this->load->model('models_login'); $number_row=$this->models_login->exist_func($email,$password);//!!! if($number_row==1){ $get_user=$this->models_login->get_id($email,$password);//!!! $this->session->set_userdata(array('id_key'=>$get_user['id'])); //Call id from session $session_id =array('id_key'=>$get_user['id']); $name_data['yourname']=$this->models_login->get_name($session_id); /* $name_data=$this->models_login->get_name($session_id); このように変数に入れてみるとviewの方のifsetに反映されない。 */ //send name for view $this->load->view('views_mainpage',$name_data); } else{ $this->load->view('views_login'); } } } public function logout(){ $this->session->sess_destroy(); redirect("controllers_login"); } } ?>
<?php class models_login extends CI_Model{ public function __construct(){ parent::__construct(); $this->load->database(); $this->load->library('session'); $this->load->helper('url'); $this->load->library('form_validation'); } public function exist_func($email,$password){ $sql="SELECT*FROM login WHERE email=? AND password=?"; $query=$this->db->query($sql,array($email,$password)); $number_result=$query->num_rows(); return $number_result; } public function get_id($email,$password){ $sql="SELECT id FROM login WHERE email=? AND password=?"; $query=$this->db->query($sql,array($email,$password)); $row=$query->row_array(); //var_dump($row); return $row; } public function get_name($session_id){ $sql="SELECT name FROM login WHERE id=?"; //var_dump($id_data); $query=$this->db->query($sql,array($session_id)); $row=$query->row_array(); var_dump($row); return $row; } } ?>
<!DOCTYPE html> <html lang="ja"> <head> <meta charset="utf-8"> <title>メインページ</title> </head> <body> <?php if(isset ($yourname)){ foreach ((array)$yourname as $data){ echo "こんにちは" .$data. "さん"; } /*if(isset($name_data)){ var_dump ($name_data); */ //コメントの部分にすると$name_dataが認識されず、elseの方に飛ぶ。 ?> <br> <a href="./logout" >ログアウト</a> <?php }else{ echo 'hello guest'; ?> <br> <a href="controllers_login/login">login</a> <?php } ?> </body> </html>
<?php if($this->form_validation->run()==FALSE){ ?> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> </head> <body> <form action="./main" method="post"> メールアドレス:<br /> <input type="text" name="email" size="30" ><br /> パスワード:<br /> <input type="password" name="password" size="30" ><br /> <input type="submit" value="送信" ><br/> <?php }else{ ?> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> </head> <body> <h3>正しいデータを入れてください。 </h3> <form action="./main" method="post"> メールアドレス:<br /> <input type="text" name="email" value="<?php echo set_value('email'); ?>" size="30" ><br /> パスワード:<br /> <input type="password" name="password" size="30" ><br /> <input type="submit" value="送信" ><br/> <?php } ?>
コントローラとメインページの方をみていただきたいのですが、
コメントアウトした部分が上手くいかなかった場合のコードです。配列の形にすると上手くいくのですが、このように変数の形では上手くいかないのはなぜなんでしょうか。
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。