Cet article présente principalement la situation des utilisateurs ajax qui sautent après s'être connectés. Vous trouverez des exemples de code détaillés ci-dessous. Les amis dans le besoin devraient rapidement y jeter un œil. Commençons maintenant l'introduction de cet article
J'ai récemment appris l'utilisation du framework TP Lorsque je travaillais sur le système de gestion backend, j'ai créé une page de connexion backend que je voulais inviter. l'utilisateur en temps réel sur l'état de retour des informations saisies
Bien sûr, en jugeant que le mauvais nom d'utilisateur et le mauvais mot de passe doivent passer par une vérification des antécédents et être affichés sur. la page sans rafraîchir, alors la première chose à laquelle penser est le traitement asynchrone (c'est la porte Art)
La méthode $this_ajaxReturn(); juger du rafraîchissement local des informations correspondantes.
Mais lorsque j'entre le nom d'utilisateur et le mot de passe corrects, je ne peux pas accéder à la page de gestion en arrière-plan et simplement renvoyer un flux de données json
Il s'avère que lorsque le mode asynchrone est utilisé pour recevoir les données renvoyées par l'arrière-plan, elles sont transmises au code js pour traitement et le flux json est ensuite renvoyé. la redirection en arrière-plan entre dans le flux au lieu de La page sera actualisée et les informations de la page ne pourront être vues qu'à travers la réponse reçue. (Si vous voulez en savoir plus, rendez-vous sur le site PHP chinois Colonne Manuel de développement AJAX pour apprendre)
Code js
$(function(){ $('button').click(function(){ var user = $('input[name=user]'); var pwd = $('input[name=pwd]'); var verify = $('input[name=verify]'); if(user.val() == ''|| pwd.val() == '') { $('[name=user]').focus(); $('#errormsg').html("<strong>用户名或密码不能为空<strong>"); return false; } else if(verify.val() == '') { $('#errormsg').html("<strong>验证码不能为空<strong>"); return false; } else{ $.ajax({ url: handle, data:{'user':user.val(),'pwd':pwd.val(),'verify':verify.val()}, type: "POST", dataType:'json', success:function(data){ if(data.status == '1'){ window.location.href = dr; } else if (data.status == '2') { $('#errormsg').html("<strong>验证码错误<strong>"); }else if (data.status == '0') { $('#errormsg').html("<strong>用户名或密码错误!<strong>"); } }, error : function(data) { alert("出错:" + data.code); } }); } }); })
Code backend
$verify = I('verify','','md5'); if($verify !== $_SESSION['verify']) { $this->ajaxReturn(array('status' =>'2')); die(); } $username=I('user','',''); $passward=I('pwd','',''); $date=M('admin',NULL); $date->where(array('username' => $username))->find(); if($date and $date->passward == $passward) { $id = $date->id; $login_time = time() ; $login_ip = get_client_ip(); $date = array('id' => $id,'login_ip' => $login_ip,'login_time' => $login_time ); M('admin')->save($date); session('uid',$date['id']); session('ip',$date['login_ip']); // $this->ajaxReturn(array('status' =>'1')); // $this->success('登陆成功',U('Admin/Admin/index')); } else { $this->ajaxReturn(array('status' =>'0')); $this->redirect('Admin/Index/index'); } }
Ce qui précède comporte également le processus d'acceptation des données de base pour déterminer si le nom d'utilisateur et le mot de passe sont corrects
Cet article se termine ici ( si vous voulez en savoir plus, rendez-vous sur PHP chinois (Apprenez dans la colonne Manuel d'utilisation AJAX du site Web. Si vous avez des questions, vous pouvez laisser un message ci-dessous).
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!