1

正しいデータベース構成、view_login を作成し、ms_user テーブルにいくつかのデータを挿入しました。そして今、ユーザー名、パスワード、役割(「学生」「教師」「校長」)などの役割でログインを作成するにはどうすればよいですか。

私はこれを参考にしましたが、このサイトではログイン、ユーザー名、パスワードの 2 つの情報しか提供されていません。3 番目の「役割」情報はどこに追加すればよいですか?

これはview_login.phpです

<html>
<head>  <title>Selamat datang pada QB Project </title></head>

<script>
    function loginsukses()
    {
            alert('Login Success');
    }
</script>

<body>
<center><h1>Selamat datang pada QB Architecture</h1></center>
<div id="form">
        <form method="POST" action="">
        <table border="1" bordercolor="gold" style="background-color:#FFFFFF" width="20%" cellpadding="2" cellspacing="4">
        <tr>
            <td class="td">Username</td>
            <td>
            <input type="text" id ="username" name ="username" class="gui" " />
            
            </td>
            
        </tr>
        
        <tr>
            <td class="td">Password</td>
            <td class="td"><input type="password" id="password" name="password" class="gui" /></td>
        </tr>
        
        <tr>
            <td class="td">Jabatan</td>
            <td class="td"><select name="jabatan" id="Jabatan" class="gui">
            <option value=“Accounting”&gt;Accounting</option>
            <option value=“Direktur”&gt;Direktur</option>
            <option value=”HeadDivisi”&gt;Head Divisi</option>
            </select></td>
        </tr>
        <tr>
            <td></td>
            <td class="td">
            <input type="submit" name="submit" value="Login" class="button" onclick="loginsukses()" />          
            </td>
        </tr>
        
    </form>
</div>



</body>
 </html>

これはモデルフォルダのログイン機能です

<?php

Class Login extends CI_Model
 {
 function login($username, $password)
 {
   $this -> db -> select('username, password, jabatan');
   $this -> db -> from('ms_user');
   $this -> db -> where('username = ' . "'" . $username . "'");
   $this -> db -> where('password = ' . "'" . MD5($password) . "'");
   $this -> db -> where('jabatan = ' . "'" . $jabatan . "'");
   $this -> db -> limit(1);
 
   $query = $this -> db -> get();
 
   if($query -> num_rows() == 1)
   {
     return $query->result();
   }
   else
   {
     return false;
   }
 }
}
?>

これはコントローラーフォルダーのvalidate_login関数です

<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');

class ValidateLogin extends CI_Controller {
 
 function __construct()
 {
   parent::__construct();
   $this->load->model('Login','',TRUE);
 }
 
 function index()
 {
   //This method will have the credentials validation
   $this->load->library('form_validation');
 
   $this->form_validation->set_rules('username', 'Username', 'trim|required|xss_clean');
   $this->form_validation->set_rules('password', 'Password', 'trim|required|xss_clean|callback_check_database');
   $this->form_validation->set_rules('Jabatan', 'Username', rim|required|xss_clean');
 
   if($this->form_validation->run() == FALSE)
   {
     //Field validation failed.  User redirected to login page
     $this->load->view('login_view');
   }
   else
   {
     //Go to private area
     redirect('qb_main', 'refresh');
   }
 
 }
 
 function check_database($password)
 {
   //Field validation succeeded.  Validate against database
   $username = $this->input->post('username');
 
   //query the database
   $result = $this->user->login($username, $password, $jabatan);
 
   if($result)
   {
     $sess_array = array();
     foreach($result as $row)
     {
       $sess_array = array(
         'id' => $row->id,
         'username' => $row->username
       );
       $this->session->set_userdata('logged_in', $sess_array);
     }
     return TRUE;
   }
   else
   {
     $this->form_validation->set_message('check_database', 'Invalid username or password');
     return false;
   }
 }
}
?>

私はこのフレームワークに非常に慣れていないので、上に書いたことを理解していませんが、喜んで学びたいと思っています。助けてください

4

1 に答える 1

0

データベースに新しい列を作成する必要があります。または、他のユーザー情報用に別のテーブルを作成し、「結合」を使用してモデルの CRUD 関数でそれらをリンクすることをお勧めします。ただし、Tank Auth ライブラリを見てください。平均的なログインよりも優れています。最初から登録してください。

于 2012-09-14T06:00:39.300 に答える