Maison >développement back-end >tutoriel php >Page d'inscription Web Vérification de correspondance dynamique Vérification de l'utilisateur Implémentation PHP
Cet article présente principalement l'implémentation PHP de la vérification des utilisateurs pour la vérification dynamique des pages d'inscription Web. Il a une certaine valeur de référence. Maintenant, je le partage avec tout le monde. Les amis dans le besoin peuvent s'y référer
Obligatoire. connaissances : 1.connexion à la base de données php
2. correspondance d'expressions régulières php
3.ajax --
Bases HTML et CSS
Créer la zone de saisie :
<input name="username" type="text" class="form-control" id="contact_username" onkeyup="loadXMLDoc(this.value)" placeholder="用户名" required/> <span id="txtHint"></span>2 :
js implémente l'effet d'invite : (texte original de : cliquez pour ouvrir le lien)
function loadXMLDoc(str) { if (str.length==0) { document.getElementById("txtHint").innerHTML=""; return; } var xmlhttp; //检查浏览器是否支持 XMLHttpRequest 对象 if (window.XMLHttpRequest) { // IE7+, Firefox, Chrome, Opera, Safari 浏览器执行代码 xmlhttp=new XMLHttpRequest(); } else { // IE6, IE5 浏览器执行代码 xmlhttp=new ActiveXObject("Microsoft.XMLHTTP"); } xmlhttp.onreadystatechange=function() { if (xmlhttp.readyState==4 && xmlhttp.status==200) { //responseText 获得字符串形式的响应数据。 document.getElementById("txtHint").innerHTML=xmlhttp.responseText; } } xmlhttp.open("GET","../common/verify.php?v="+str,true); xmlhttp.send(); }3 : le code php implémente la vérification dynamique : (la vérification est défectueuse car il a été écrit par moi-même, Il y a beaucoup d'endroits qui ne sont pas parfaits, je vais continuer à m'améliorer)
<?php //注册验证---------- $v=trim($_GET['v']); //获取用户输入的账号 $hint = ""; //用作返回输出 //判断是账号还是密码,或者其他匹配 //判断输入的账账号长度是否大于0 if (strlen($v) > 0) { //用户验证 //1.必须以字母开头 if(preg_match("/^[a-z]/",$v)){ //2.至少5个字符 if(preg_match("/^[a-z][\w]{4}/",$v)) { echo $v; $hint = ""; //当满足时,让它输入空 因为前面不满足赋值了 //数据库建立连接 require "mysqli.php"; //数据库查询语句--查询输入的账号是否存在 $sql="select `username` from `user` where `username`='$v'"; $result = mysqli_query($conn, $sql); //当mysqli_num_rows($result)> 说明查到里数据 if(mysqli_num_rows($result) > 0){ $hint ="该用户已存在!"; }else{ $hint = "该用户可用"; } mysqli_close($conn); //关闭数据库连接 }else{ $hint = "至少5个字符!"; } }else{ $hint = "必须以字母开头!"; } } if ($hint == "") { $response=""; } else { $response=$hint; } //打印返回 echo $response; ?>
更新:(2018年6月5日14:31:00)
//判断输入的账账号长度是否大于0if (strlen($v) > 0) { //用户验证 //1.必须以字母开头 if (preg_match("/^[a-z]/", $v)) { //2.至少5个字符最长不超过11个字符 if (strlen($v) 11) { $hint = "至少5个字符,最长不超过11个字符!"; } else { //3.模式匹配 if (preg_match("/^[a-z][\w]{2,10}$/", $v)) { echo $v; $hint = ""; //当满足时,让它输入空 因为前面不满足赋值了 //数据库建立连接 require "mysqli.php"; //数据库查询语句--查询输入的账号是否存在 $sql = "select `username` from `user` where `username`='$v'"; $result = mysqli_query($conn, $sql); //当mysqli_num_rows($result)> 0 说明查到里数据 if (mysqli_num_rows($result) > 0) { $hint = "该用户已存在!"; } else { $hint = "该用户可用"; } mysqli_close($conn); //关闭数据库连接 }else { $hint = "用户名只能是数值,字母,下划线"; } } } else { $hint = "必须以字母开头!"; } }4 : Il est entièrement basé sur mon propre compréhension et mon expression et explication orales, qui ne sont pas assez professionnelles ou standard, veuillez signaler s'il y a des erreurs : QQ363491343Explication : Lorsque nous saisissons le nom d'utilisateur à enregistrer dans la saisie du nom d'utilisateur. case, la fonction appelle la méthode loadXMLDoc() (voir étape 2) pour effectuer une vérification dynamique pertinente (voir cliquez pour ouvrir le lien pour plus de détails)
$v=trim($_GET['v']);Utilisé pour obtenir le nom d'utilisateur saisi dynamiquement par l'utilisateur 2.
if (strlen($v) > 0)Le nom d'utilisateur saisi par l'utilisateur doit être supérieur à 0 c'est le plus basique. 3.
if(preg_match("/^[a-z]/",$v)){Ensuite, j'ai stipulé que le nom d'utilisateur doit commencer par une lettre et n'est pas sensible à la casse4.
C'est-à-dire que je veux que le nom d'utilisateur comporte au moins 5 caractères ;
5.echo $v;$hint = ""; //当满足时,让它输入空 因为前面不满足赋值了 //数据库建立连接 require "mysqli.php";//数据库查询语句--查询输入的账号是否存在 $sql="select `username` from `user` where `username`='$v'"; $result = mysqli_query($conn, $sql);//当mysqli_num_rows($result)> 说明查到里数据 if(mysqli_num_rows($result) > 0){ $hint ="该用户已存在!"; }else{ $hint = "该用户可用";}mysqli_close($conn); //关闭数据库连接Cette partie est lorsque tous les éléments ci-dessus sont satisfaits, effectuez une recherche dynamique dans le base de données pour voir si l'utilisateur existe déjà. 6.
if ($hint == ""){ $response=""; }else{ $response=$hint;}//打印返回echo $response;La sortie finale renvoie le contenu à afficher J'ai vérifié ici que la sortie d'écho en PHP est le contenu renvoyé ; Si php a un message d'avertissement ou si une erreur se produit, il sera renvoyé au front-end. Si vous apprenez bien ajax, alors le code suivant sera facile à comprendre :
xmlhttp.onreadystatechange=function() { if (xmlhttp.readyState==4 && xmlhttp.status==200) { //responseText 获得字符串形式的响应数据。 document.getElementById("txtHint").innerHTML=xmlhttp.responseText; } }
当焦点离开输入框,隐藏提示信息
//当焦点离开输入框,隐藏提示信息function upperCase(){ document.getElementById("txtHint").innerHTML="";}à l'intérieur de
<input><span></span>Ajouter le même événement onblur
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!