Php mysql connexion
Résolu/Fermé
kihonen
Messages postés
7
Date d'inscription
vendredi 28 janvier 2022
Statut
Membre
Dernière intervention
31 janvier 2022
-
28 janv. 2022 à 16:47
kihonen Messages postés 7 Date d'inscription vendredi 28 janvier 2022 Statut Membre Dernière intervention 31 janvier 2022 - 31 janv. 2022 à 10:18
kihonen Messages postés 7 Date d'inscription vendredi 28 janvier 2022 Statut Membre Dernière intervention 31 janvier 2022 - 31 janv. 2022 à 10:18
A voir également:
- Php mysql connexion
- Gmail connexion - Guide
- Gmail connexion autre compte - Guide
- Connexion chromecast - Guide
- Mysql community server - Télécharger - Bases de données
- Site inaccessible n'autorise pas la connexion - Guide
2 réponses
jordane45
Messages postés
38467
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
19 avril 2025
4 741
28 janv. 2022 à 17:00
28 janv. 2022 à 17:00
Bonjour,
Déjà, pour poster du code sur le forum, merci à l'avenir de le faire en utilisant les balises de code.
Explications à lire ici
https://codes-sources.commentcamarche.net/faq/11288-poster-un-extrait-de-code
Ensuite...
Ce if ne sert à rien ( et est faux de toutes façons )
Et enfin.. attention à ne pas stocker les mots de passe en clair dans la bdd
il faut les "crypter" ...
Regarde la fonction password_hash
Je t'invite également à activer la gestion des erreurs PDO dans ton code pour être sûr de ne pas avoir d'erreurs dans tes requêtes
https://forums.commentcamarche.net/forum/affich-37584941-php-pdo-gerer-les-erreurs
Déjà, pour poster du code sur le forum, merci à l'avenir de le faire en utilisant les balises de code.
Explications à lire ici
https://codes-sources.commentcamarche.net/faq/11288-poster-un-extrait-de-code
Ensuite...
Ce if ne sert à rien ( et est faux de toutes façons )
if ($result == $username) {
Et enfin.. attention à ne pas stocker les mots de passe en clair dans la bdd
il faut les "crypter" ...
Regarde la fonction password_hash
Je t'invite également à activer la gestion des erreurs PDO dans ton code pour être sûr de ne pas avoir d'erreurs dans tes requêtes
https://forums.commentcamarche.net/forum/affich-37584941-php-pdo-gerer-les-erreurs
kihonen
Messages postés
7
Date d'inscription
vendredi 28 janvier 2022
Statut
Membre
Dernière intervention
31 janvier 2022
31 janv. 2022 à 10:04
31 janv. 2022 à 10:04
alors pour le code :
et le message d'erreur est :
Notice: Trying to access array offset on value of type bool in /home/u783201149/domains/xn--trechy-auto-bilan-9sb.com/public_html/contenu/base.php on line 16
<?php session_start(); if (isset($_POST['username'], $_POST['password'])) { $username = $_POST['username']; $pass = $_POST['password']; $db = new PDO('mysql:host=localhost;dbname=u783201149_Util;charset=utf8', 'u783201149_admin', 'Admin2003'); $db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $sql = "SELECT * FROM 'User' where username = ?"; $result = $db->prepare($sql); $result->execute(array($username)); $data = $result->fetch(); if ($pass == $data['password']) { echo "Connexion effectuée"; $_SESSION['username'] = $username; } } else { $db = new PDO('mysql:host=localhost;dbname=u783201149_Util;charset=utf8', 'u783201149_admin', 'Admin2003'); $sql = "INSERT INTO `User` (`username`, `password`) VALUES (?, ?)"; $result = $db->prepare($sql); $result->execute(array($username, $pass)); echo "Enregistrement effectué"; } ?>
et le message d'erreur est :
Notice: Trying to access array offset on value of type bool in /home/u783201149/domains/xn--trechy-auto-bilan-9sb.com/public_html/contenu/base.php on line 16
jordane45
Messages postés
38467
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
19 avril 2025
4 741
31 janv. 2022 à 10:10
31 janv. 2022 à 10:10
Déjà .. tu n'as pas besoin de refaire une connexion à la bdd à 50 endroits dans ton code...
Tu la fait UNE fois au début du ficher .. ça suffira.
Ensuite.. tu n'as pas appliqué exactement ce qui est donné dans le lien..
Il manque les TRY/CATCH
Et enfin.. ton erreur vient certainement de ta requête SQL .. et des quotes que tu as mis autour du nom de ta table.
Tu la fait UNE fois au début du ficher .. ça suffira.
Ensuite.. tu n'as pas appliqué exactement ce qui est donné dans le lien..
Il manque les TRY/CATCH
Et enfin.. ton erreur vient certainement de ta requête SQL .. et des quotes que tu as mis autour du nom de ta table.
kihonen
Messages postés
7
Date d'inscription
vendredi 28 janvier 2022
Statut
Membre
Dernière intervention
31 janvier 2022
31 janv. 2022 à 10:10
31 janv. 2022 à 10:10
et avec les erreurs activée je passe à ça : : Uncaught PDOException: SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near ''User' where username = 'Remond'' at line 1 in /home/u783201149/domains/xn--trechy-auto-bilan-9sb.com/public_html/contenu/base.php:14 Stack trace: #0 /home/u783201149/domains/xn--trechy-auto-bilan-9sb.com/public_html/contenu/base.php(14): PDOStatement->execute(Array) #1 {main} thrown in /home/u783201149/domains/xn--trechy-auto-bilan-9sb.com/public_html/contenu/base.php on line 14
jordane45
Messages postés
38467
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
19 avril 2025
4 741
>
kihonen
Messages postés
7
Date d'inscription
vendredi 28 janvier 2022
Statut
Membre
Dernière intervention
31 janvier 2022
31 janv. 2022 à 10:11
31 janv. 2022 à 10:11
regarde ma réponse précédente
kihonen
Messages postés
7
Date d'inscription
vendredi 28 janvier 2022
Statut
Membre
Dernière intervention
31 janvier 2022
>
jordane45
Messages postés
38467
Date d'inscription
mercredi 22 octobre 2003
Statut
Modérateur
Dernière intervention
19 avril 2025
31 janv. 2022 à 10:18
31 janv. 2022 à 10:18
merci beaucoup , maintenant ça marche , donc merci de la patience dont tu as fais preuve avec un néophyte comme moi.
je devrais m'en sortir avec le cryptage du mot de passe et le try / catch donc merci .
je devrais m'en sortir avec le cryptage du mot de passe et le try / catch donc merci .
28 janv. 2022 à 17:10
28 janv. 2022 à 17:52
28 janv. 2022 à 18:01
28 janv. 2022 à 18:35
31 janv. 2022 à 09:00
il me dit ça pour le if du mot de passe .