Comparer un élément en javascript récupérer dans ma BD
AbertBlanchar123
-
AlbertBlanchar123 -
AlbertBlanchar123 -
Bonjour,
J'ai un petit souci, lors de l'enregistrement d'un login dans ma BD, j'aimerais vérifier qu'un login n’hésite pas déjà avant de valider, j'ai décider de passer par le jQuery. (je rappel que je débute :)
j'aimerais vérifier que le login n’hésite pas dans la BD avant de l’insérer.
code HTML
code PHP
code JS
Tout en vous remerciant.
J'ai un petit souci, lors de l'enregistrement d'un login dans ma BD, j'aimerais vérifier qu'un login n’hésite pas déjà avant de valider, j'ai décider de passer par le jQuery. (je rappel que je débute :)
j'aimerais vérifier que le login n’hésite pas dans la BD avant de l’insérer.
code HTML
<div style="display: none;" id="erreur" class="alert alert-danger">
<p>Vous n'avez pas rempli ce champ !</p>
</div>
<form class="form" action="insert.php" role="form" method="post" enctype="multipart/form-data">
<div class="form-group">
<label for="nom">Login:</label>
<input type="text" class="form-control" id="login" name="login" placeholder="Login" value="<?php echo $login;?>">
</div>
<br>
<div class="form-actions">
<button type="submit" class="btn btn-success" name="envoi" id="envoi"><span class="glyphicon glyphicon-pencil"></span> Ajouter</button>
<a class="btn btn-primary" href="index.php"><span class="glyphicon glyphicon-arrow-left"></span> Retour</a>
</div>
</form>
code PHP
<?php
require 'database.php';
if(!empty($_POST))
{
$login = $_POST['login'];
$db = Database::connect();
$statement = $db->prepare("INSERT INTO users (login) values(?)");
$statement->execute(array($login));
Database::disconnect();
header("Location: index.php");
}
?>
code JS
$(document).ready(function(){
var $login = $('#login'),
$envoi = $('#envoi'),
$erreur = $('#erreur'),
$tot1;
//on m'a conseiller de l'utiliser mais j'ai pas compris
$.ajax({
url : "insert.php",
type : "POST",
value : $login
});
$login.keyup(function(){
if($(this).val() == $login){ // c'est ici que je voulais comparer si le champ existe a un login de la BD
$tot1=0;
$(this).css({ // on rend le champ rouge
borderColor : 'red',
color : 'red'
});
}
else{
$tot1=1;
$(this).css({ // si tout est bon, on le rend vert
borderColor : 'green',
color : 'green'
});
}
});
$envoi.click(function(e){
e.preventDefault();
verifier($login);
if($tot1==1 ){
$erreur.css('display', 'none');
}
else{
$erreur.css('display', 'block');
}
});
});
Tout en vous remerciant.
A voir également:
- Comparer un élément en javascript récupérer dans ma BD
- Comment recuperer un message supprimé sur whatsapp - Guide
- Comment récupérer un document dans le presse-papier samsung - Guide
- Comment récupérer un compte facebook piraté - Guide
- Récupérer mon compte facebook désactivé - Guide
- Comment recuperer une video sur youtube - Guide
4 réponses
Côté JS ça donnerait un truc du genre :
et côté PHP il te faut un fichier (verifyLogin.php) qui servira à la vérification:
NB: Pense à regarder dans la CONSOLE de ton navigateur lorsque tu testes le script pour voir si il n'y aurait pas des messages d'erreur.
NB² : Je t'invite fortement à lire ces deux liens avant de continuer :
https://forums.commentcamarche.net/forum/affich-37584941-php-pdo-gerer-les-erreurs
https://forums.commentcamarche.net/forum/affich-37584947-php-gestion-des-erreurs-debogage-et-ecriture-du-code
.
$(document).ready(function(){ var $login = $('#login'), $envoi = $('#envoi'), $erreur = $('#erreur'), $tot1; //on vérifie lors du keyUp sur le champ login $login.keyup(function(){ verifyLogin($login.val()); }); //Submit du formulaire $envoi.click(function(e){ e.preventDefault(); verifyLogin($login.val()); if($tot1 == true ){ //le login existe déjà $erreur.html('ce login est déjà pris'); }else{ //le login n'existe pas déjà } }); }); function verifyLogin(input_login){ $.ajax({ method: "POST", dataType: "json", url: "verifyLogin.php", data: { login: input_login} }) .done(function( result ) { console.log(result); var error = typeof(result.error) !='undefined' ? result.error : null; var reponse = typeof(result.reponse) !='undefined' ? result.reponse : null; if(error){ alert(error); }else{ if(reponse){ $login.css({ // on rend le champ rouge borderColor : 'red', color : 'red' }); $tot1 = true; }else{ $login.css({ // on rend le champ rouge borderColor : 'green', color : 'green' }); $tot1 = false; } } }); }
et côté PHP il te faut un fichier (verifyLogin.php) qui servira à la vérification:
<?php //fichier verifyLogin.php //activation des erreurs PHP //Affichage des erreurs PHP error_reporting(E_ALL); ini_set('display_errors', TRUE); ini_set('display_startup_errors', TRUE); //connexion à la bdd require_once 'database.php'; $db = Database::connect(); //initialisation de la variable de retour $result = array('reponse'=>NULL,'error'=>NULL); //récupération PROPRE des variables $login = !empty($_POST['login']) ? trim($_POST['login']) : NULL; if($login){ $sql = "SELECT * FROM users WHERE login = ?"; $datas = array($login); //exécution de la requête try{ $statement = $db->prepare($sql); $statement->execute($datas); //on stocke le resultat dans un array $queryResult = $statement->fetchAll(); $result['reponse'] = !empty($queryResult) ? $queryResult : NULL; }catch(Exception $e){ $result['error'] = $e->getMessage(); } } Database::disconnect(); //on renvoi les données au format JSON echo json_encode($result); ?>
NB: Pense à regarder dans la CONSOLE de ton navigateur lorsque tu testes le script pour voir si il n'y aurait pas des messages d'erreur.
NB² : Je t'invite fortement à lire ces deux liens avant de continuer :
https://forums.commentcamarche.net/forum/affich-37584941-php-pdo-gerer-les-erreurs
https://forums.commentcamarche.net/forum/affich-37584947-php-gestion-des-erreurs-debogage-et-ecriture-du-code
.
Bonjour,
Il faut placer la vérification dans la méthode SUCCESS ou DONE de ton ajax
Voici des exemples :
https://codes-sources.commentcamarche.net/source/102253-exemple-ajax-en-jquery
Il faut placer la vérification dans la méthode SUCCESS ou DONE de ton ajax
Voici des exemples :
https://codes-sources.commentcamarche.net/source/102253-exemple-ajax-en-jquery