Foros del Web » Programando para Internet » Jquery »

Ajax con JQuery en Codeigniter

Estas en el tema de Ajax con JQuery en Codeigniter en el foro de Jquery en Foros del Web. Hola amigos foreros, nuevamente me acerco a ustedes con este problema: Tengo un formulario para iniciar sesión hecho con Codeigniter 1.7.2 y Ajax con Jquery. ...
  #1 (permalink)  
Antiguo 12/10/2011, 09:24
Avatar de p3rikl3s  
Fecha de Ingreso: febrero-2009
Ubicación: Valencia
Mensajes: 216
Antigüedad: 15 años, 9 meses
Puntos: 9
Exclamación Ajax con JQuery en Codeigniter

Hola amigos foreros, nuevamente me acerco a ustedes con este problema: Tengo un formulario para iniciar sesión hecho con Codeigniter 1.7.2 y Ajax con Jquery. Cuando actualice Codeigniter de 1.7.2 a la versión 2.0.0 el Ajax dejo funcionar. Investigue al respecto y conseguí que Codeigniter 2 añade una característica de seguridad importante para evitar ataques CSRF (Cross Site Request Forgery). COnseguí una posible solución http://aymsystems.com/ajax-csrf-prot...codeigniter-20 pero no veo como ajustarla a mi código:

Vista: Formulario iniciar_sesion

Código PHP:

<head>
<script src="<?=base_url()?>js/jquery.js" type="text/javascript"></script>    
<script src="<?=base_url()?>js/ajaxlogin.js" type="text/javascript"></script>
</head>

<div id="form-oldschool">

<?php echo form_open('welcome/login',array('id' => 'userlogin''class' => 'gen-form')); ?>


    <fieldset>
        <label for="username">Username</label>
<input class="text-input" id="username" name="username" tabindex="1" type="text" value="" />
    </fieldset>
    

    <fieldset>
        <label for="password">Password</label>
        <input class="text-input" id="password" name="password" tabindex="2" type="password" value="" />
    </fieldset>

    <input class="button" type="submit" value="Ingresar" tabindex="3" />
<?php echo form_close('');?>

</div>

Controlador: (uso una libreria para autentificación llamada Redux Auth )

Código PHP:

function login()
    {
        
$this->form_validation->set_rules('username''Username''required');
        
$this->form_validation->set_rules('password''Password''required');
        
$this->form_validation->set_error_delimiters('<p class="error">''</p>');
        
        
       
        if (
$this->form_validation->run() == false)         
             
            
$this->load->view('iniciar_sesion');
             
            
        }
        
        
        else
        {
            
$email    $this->input->post('username');
            
$password $this->input->post('password');            
            
$login $this->redux_auth->login($email$password);            
            
redirect('welcome/sesion');
        }
    }
    
    
    
    
    
    
    function 
_check_login($email)
    {
        return 
$this->redux_auth->login($email$this->password);
    }
    
    
    
    
    
    function 
ajaxlogin()
    {
        
$this->load->library('validation');
        
        
$this->password $this->input->post('password');
        
$this->loginemail $this->input->post('username');
        
        
$this->form_validation->set_rules('username''Username''trim|required|callback__check_login');
        
$this->form_validation->set_rules('password''Password''trim|required');
        
         
        if((
$this->loginemail!='')and($this->password!='')){
        
        
        if (
$this->form_validation->run() == false)
        {
            
$data = array(    'success' =>    'no',
                            
'message' =>    '<div align="center"><h2>Username y/o Password incorrectos!</h2></div>');
            
            
$output json_encode($data);
        }
        else
        {
            if (
$this->redux_auth->logged_in())
        {
           
$usuario $this->redux_auth->profile();      
           
$usuario $usuario->group;             
              
        }
            
                        
            
$data = array(    'success' =>    'yes',
                            
'welcome' =>    $usuario);                        
            
$output json_encode($data);
        }
        
        
$output str_replace("\r"""$output);
        
$output str_replace("\n"""$output);
        
        echo 
$output;
        
        }
    } 


Ajaxlogin.js

Código:

$(document).ready(
    function(){
    
        $("#userlogin").ajaxForm({
            type: "POST",
            url: "http://localhost/CI/welcome/ajaxlogin",
            dataType: "json",			
            data:"username="+$("#username").val()+"&password;="+$("#password").val(),
            success: updateLogin
        });
    
    }
)

function updateLogin(data) {
    $('#logged').html('');
    $('#logged').hide();
    
    $("#form-oldschool").fadeOut("slow",
        function() {
             if (data.success == 'yes') {
              
		location.href='http://localhost/CI/welcome/'+data.welcome;
				
				
            }
            
            if (data.success == 'no') {
                $('#loginerror').html(data.message).fadeIn("slow").fadeOut(5000,
                    function() {
                        $("#form-oldschool").fadeIn("slow");
                    }
                );    
            }
        }
    );
    
}

Cuando quito el ajaxlogin.js de la vista, funciona bien, solo que sin el ajax. Cuando coloco el ajaxlogin.js me arroja el Firebug error 500. ¿Que puede ser? ¿Como puedo implementar la solución que muestro mas arriba a mi código? De antemano muchas gracias
__________________
También me hago llamar Tropiburguer. Sígueme en twitter: @tropiburguer
  #2 (permalink)  
Antiguo 12/10/2011, 11:18
Avatar de p3rikl3s  
Fecha de Ingreso: febrero-2009
Ubicación: Valencia
Mensajes: 216
Antigüedad: 15 años, 9 meses
Puntos: 9
Respuesta: Ajax con JQuery en Codeigniter

¿Alguien tiene alguna idea?

Última edición por p3rikl3s; 12/10/2011 a las 12:18

Etiquetas: ajax
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 14:28.