2011-12-31 11 views
0

ユーザーログイン資格情報を検証するために、ログインフォーム送信をどのように使用するべきかを判断しようとしています。このテンプレートでは、JavaScriptの検証コードが含まれていますが、私は(PHP)を使いたいサーバー側に独自の検証コードを持っています。それがPHPの検証を経た後、ログインの検証に問題があった場合はログインフォームに再度リダイレクトするか、ログインが成功した場合はダッシュボードにリダイレクトします。ログインフォーム検証の処理

JSの検証:

$(window).load(function(){ 
/* 
* Validate the form when it is submitted 
*/ 
var validatelogin = $("form").validate({ 
    invalidHandler: function(form, validator) { 
     var errors = validator.numberOfInvalids(); 
     if (errors) { 
      var message = errors == 1 
       ? 'You missed 1 field. It has been highlighted.' 
       : 'You missed ' + errors + ' fields. They have been highlighted.'; 
      $('.box .content').removeAlertBoxes(); 
      $('.box .content').alertBox(message, {type: 'warning', icon: true, noMargin: false}); 
      $('.box .content .alert').css({ 
       width: '', 
       margin: '0', 
       borderLeft: 'none', 
       borderRight: 'none', 
       borderRadius: 0 
      }); 
     } else { 
      $('.box .content').removeAlertBoxes(); 
     } 
    }, 
    showErrors : function(errorMap, errorList) { 
      this.defaultShowErrors(); 
      var self = this; 
      $.each(errorList, function() { 
       var $input = $(this.element); 
       var $label = $input.parent().find('label.error').hide(); 
       $label.addClass('red'); 
       $label.css('width', ''); 
       $input.trigger('labeled'); 
       $label.fadeIn(); 
      }); 
    }, 
    submitHandler: function(form) { 
     window.location.replace('dashboard.html'); 
    } 
}); 
}); 

コントローラー:

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

class Usermanagement extends CI_Controller { 

public function __construct() 
{ 
    parent::__construct(); 
} 

public function index() 
{ 
    //Config Defaults Start 
    $msgBoxMsgs = array();//msgType = dl, info, warn, note, msg 
    $cssPageAddons = '';//If you have extra CSS for this view append it here 
    $jsPageAddons = '';//If you have extra JS for this view append it here 
    $metaAddons = '';//Sometimes there is a need for additional Meta Data such in the case of Facebook addon's 
    $siteTitle = '';//alter only if you need something other than the default for this view. 
    //Config Defaults Start 


    //examples of how to use the message box system (css not included). 
    //$msgBoxMsgs[] = array('msgType' => 'dl', 'theMsg' => 'This is a Blank Message Box...'); 

    /**********************************************************Your Coding Logic Here, Start*/ 

    if(!$this->session->userdata('logged_in')) 
    { 
     $bodyContent = "login";//which view file 
    } 
    else 
    { 
     $bodyContent = "cpanel/index";//which view file 
    } 

    $bodyType = "full";//type of template 

    /***********************************************************Your Coding Logic Here, End*/ 

    //Double checks if any default variables have been changed, Start. 
    //If msgBoxMsgs array has anything in it, if so displays it in view, else does nothing.  
    if(count($msgBoxMsgs) !== 0) 
    { 
     $msgBoxes = $this->msgboxes->buildMsgBoxesOutput(array('display' => 'show', 'msgs' =>$msgBoxMsgs)); 
    } 
    else 
    { 
     $msgBoxes = array('display' => 'none'); 
    } 

    if($siteTitle == '') 
    { 
     $siteTitle = $this->metatags->SiteTitle(); //reads 
    } 

    //Double checks if any default variables have been changed, End. 

    $this->data['msgBoxes'] = $msgBoxes; 
    $this->data['cssPageAddons'] = $cssPageAddons;//if there is any additional CSS to add from above Variable this will send it to the view. 
    $this->data['jsPageAddons'] = $jsPageAddons;//if there is any addictional JS to add from the above variable this will send it to the view. 
    $this->data['metaAddons'] = $metaAddons;//if there is any addictional meta data to add from the above variable this will send it to the view. 
    $this->data['pageMetaTags'] = $this->metatags->MetaTags();//defaults can be changed via models/metatags.php 
    $this->data['siteTitle'] = $siteTitle;//defaults can be changed via models/metatags.php 
    $this->data['bodyType'] = $bodyType; 
    $this->data['bodyContent'] = $bodyContent; 
    $this->load->view('usermanagement/index', $this->data); 
} 

function login() 
{ 
    $this->form_validation->set_rules('username', 'Username', 'trim|required|max_length[50]|xss_clean'); 
    $this->form_validation->set_rules('password', 'Password', 'trim|required|max_length[12]|xss_clean'); 

    if ($this->form_validation->run() == FALSE) 
    { 
     $this->index(); 
    } 
    else 
    { 
     $username = $this->input->post('username'); 
     $password = $this->input->post('password'); 

     $user_id = $this->loggedin->check_login($username, $password); 

     if(! $user_id) 
     { 
      redirect('/'); 
     } 
     else 
     { 
      $this->session->set_userdata(array(
       'logged_in' => TRUE, 
       'user_id' => $user_id 
      )); 
      redirect('cpanel/index'); 
     } 
    } 
} 

function logout() 
{ 
    $this->session->sess_destroy(); 
    $this->index(); 
}  

} 

/* End of file usermanagement.php */ 
/* Location: ./application/controllers/usermanagement.php */ 

任意のアイデア?

+0

あなたの質問は何ですか? – Pointy

+0

私は何をしていますか?私はそれがjsかphp経由で私のダッシュボードに行くべきか? –

+1

フィードバックをすばやく提供できるので、クライアント側で検証するのはいいですが、サーバー側で検証することは必須です**。したがって、サーバー側の検証だけを行うことも、両方を行うこともできます。ルールの2つのセットが当然同意していることを確認してください。 – Pointy

答えて

1

私が正しく理解していれば、あなたの質問は、ログに記録されたユーザーの検証を検出する方法です。 CodeIgniterコントローラの機能では、それを調べることができ、echoのコードでそれを理解することができます(JavaScript)。たとえば、次のように返します。

if(valid){ 
    echo "1, You're logged in successfully"; 
} 

次に、JSで分割してコードとメッセージ部分を使用することができます。 JSの使用とナビゲーションのための

window.location.href = 'yourlocation';

ご質問はCI機能を取得し、jQueryのAJAXでそれを使用する方法に関連している場合、私はあなたが同じようにそれを使用できることを伝えることができ昔のこと。 url: 'yourrootfolder/yourcontroller/yourfunction'

このヘルプが必要です。

関連する問題