0

したがって、2つの関数/条件に使用されるフォームがあります:Save(add)とUpdate Now私は入力テキストにルールを設定します:$this->form_validation->set_rules('ID_user', 'User ID', 'required');

ロジックは次のようになります。ユーザーが保存状態の場合、IDを入力するため、入力テキストは有効になりますが、ユーザーが更新状態の場合、入力テキストは無効になり、テキストは現在のユーザーになります。ユーザーIDを変更できないためです。

これは私のコントローラーの保存(追加)および更新機能です:

function add(){
    //set common properties 
    $data['title'] = 'Tambah User baru';
    $data['action'] = site_url('user/add');
    $data['link_back'] = anchor('user/index/', 'Back to User list', array('class'=>'back'));

    $this->_set_rules();
    //run validation
    if($this->form_validation->run() == false){
        $data['message'] = '';
        //bedakan add/update
        $data['validate'] = 'add';
        //set common properties 
        $data['title'] = 'Add new User';
        //$data['message'] = '';
        $data['user']['ID_user'] = '';
        $data['user']['pass'] = '';
        $data['user']['nama'] = '';
        $data['user']['email'] = '';
        $data['user']['active'] = '';
        $data['link_back'] = anchor('user/index/', 'Lihat daftar User', array('class'=>'back'));

        $this->load->view('user_form_v', $data);
    }

    else{
        //save data
        $user = array('ID_user'=>$this->input->post('ID_user'),
        'pass'=>sha1($this->input->post('pass')),
        'nama'=>$this->input->post('nama'),
        'email'=>$this->input->post('email'),
        'active'=>$this->input->post('active'),
        'regis_date'=>date('Y-m-d H:i:s'));

        $ID_user = $this->user_m->save($user);

        //set form input nama = "id"
        $this->validation->ID_user = $ID_user;

        redirect('user/index/add_success');
    }
}

function update($ID_user){
    //set common properties
    $data['title'] = 'Update user';
    $this->load->library('form_validation');

    //set validation properties
    $this->_set_rules();
    $data['action'] = ('user/update/'.$ID_user);

    //bedakan add/update
    $data['validate'] = 'update';

    //run validation
    if ($this->form_validation->run() == false){
        $data['message'] = '';

        $data['user'] = $this->user_m->get_by_id($ID_user)->row_array();
        //set common properties
        $data['title'] = 'Update User';
        $data['message'] = '';
    }
    else{
        //save data
        $ID_user = $this->input->post('ID_user');
        $user = array(
        'pass'=>$this->input->post('pass'),
        'nama'=>$this->input->post('nama'),
        'email'=>$this->input->post('email'),
        'active'=>$this->input->post('active'),
        'regis_date'=>date('Y-m-d H:i:s'));

        $this->user_m->update($ID_user, $user);
        $data['user'] = $this->user_m->get_by_id($ID_user)->row_array();

        //set user message
        $data['message'] = 'Update User Success!';
    }

    $data['link_back'] = anchor('user/index/', 'Lihat daftar user', array('class'=>'back'));
    //load view
    $this->load->view('user_form_v', $data);
}

そして、これはビューの入力タイプです:

<input type="text" name="ID_user" class="text"
                <?php if($validate!='add'){echo "disabled";} ?>
                value="<?php echo (isset($user['ID_user']))?$user['ID_user']:""?>"/>

質問は:私のユーザーが更新条件にあり、更新したいときに、phpがユーザーIDがnullであると考えているため、エラーメッセージが表示されます。実際には、ユーザーIDはすでに存在します。私が行うのは、ユーザーIDを印刷することだけです。私の入力タイプとそれを無効にしました これはエラーメッセージです:The User ID field is required.

4

2 に答える 2

2

2 つの異なるルールを実行する必要があります。1 つは「保存」用、もう 1 つは「更新」用です。

次に、保存ルールに、ユーザー ID のルールを含めます。

更新ルールには、ユーザー ID を含めないでください。

ユーザー ID をフォームの「非表示」フィールドに入れるのは最適ではありません。誰かがページを「編集」して非表示フィールドを別のものに変更できるため、アプリケーションが操作される可能性があります。

于 2012-09-08T09:19:34.610 に答える
1

ユーザー ID フィールドを非表示フィールドとして更新フォームに含めて、残りのフォーム フィールドと共に送信されるようにすることができます。

<input type="hidden" name="user[ID_user]" value="<?=$user['ID_user']?>" />

現在ログインしているユーザーに対して何らかの方法で検証して、誰もそれをサルにして別のユーザーのレコードを変更しないようにしてください。

于 2012-09-08T09:26:53.207 に答える