0

私はCIにかなり慣れていないので、CIを使用してプロジェクトを進めています。

CI 2.1.2DataMapper1.8.2.1を使用しています。

ログインフォームをhttp://www.example.com/userauthcontroller/loginに投稿しようとしています 。関数を押すことができ、正常に認証されます。主にDataMapperの例とコードを使用します。

Userauthcontroller.php:

public function login(){
    $params = $this->input->post();
    $url = $params['url'];
    $loginId = $params['loginid'];
    $password = $params['loginpass'];
    $u = new User();
    $u->username = $loginId;
    $u->pass_word =$password;
    if($u->login()){
        $confirmedUser = $u->get_where(array('id' => $u->id));
        $CI =& get_instance();
        $CI->session->set_userdata(array('currentuser' => $confirmedUser));
        //print_r($CI->session->userdata('currentuser'); // works
        //die();
        //tried this too
        //$this->session->set_userdata(array('currentuser' => $confirmedUser));
        redirect($url);
    }else{
        echo '<p>' . $u->error->login . '</p>';
    }
}

ウェルカムコントローラにリダイレクトすると、セッションでcurrentuserが見つかりません。

welcome.php:

function index(){
    $data['site_title'] = "My Site Title";
    $data['view_file'] = "layout_views/home_view";

    $CI =& get_instance();
    $user = $CI->session->userdata('currentuser');

    $data['currentuser'] = $user;
    print_r($user);
    print("<BR/>");
    print_r($data);
    die();
    //If I let this continue into my view $currentuser is not available.
    $this->load->view('index_view', $data);
}

home_view.php:

<p><? echo $currentuser ?></p> <!-- this does not print -->
<p><? echo $site_title ?></p>  <!-- this prints -->

application / config / autoload.php :(私が知っている関連エントリ)

$autoload['libraries'] = array('database', 'datamapper', 'session');
$autoload['packages'] = array(APPPATH.'third_party/datamapper');

私はこれについて少し検索しました...そして私はスペルミスさえチェックしました。

任意の提案をいただければ幸いです。

さらに詳しい情報が必要な場合は、ここで頻繁に確認します。

ありがとう

4

1 に答える 1

0

ヤンのおかげで、私は正しい方向に向かった。これが最善の方法かどうかはわかりませんが、機能しています。

userauthcontroller.php:

public function login(){
    $params = $this->input->post();
    $url = $params['url'];
    $loginId = $params['loginid'];
    $password = $params['loginpass'];
    $u = new User();
    $u->username = $loginId;
    $u->pass_word =$password;
    if($u->login()){
        $confirmedUser = new User(array('id' => $u->id));
        $CI =& get_instance();
        $CI->session->set_userdata(array('currentuser_id' => $u->id));
        $CI->session->set_userdata(array('currentuser' => $confirmedUser));
        redirect($url);
    }else{
        echo '<p>' . $u->error->login . '</p>';
    }
}

welcome.php:

    function index(){
    $data['site_title'] = "PrimitiveSurvival.com";
    $data['view_file'] = "layout_views/home_view";
    $CI =& get_instance();
    $u = new User($CI->session->userdata('currentuser_id'));
    if($u->id != null){
        $u->group->get_iterated();
        $data['currentuser'] = $u;
    }else{
        $data['currentuser'] = "";
    }
    $this->load->view('index_view', $data);
}

home_view.php:

 <?php
  if($currentuser != ""){
     print($currentuser->username);
  }else{
     print("User not logged in.");
  }

もっと良い方法や欠けているものがあれば、ぜひこの答えを改善してください。?>

于 2012-07-20T16:17:15.193 に答える