Mit der Entwicklung des Internets beginnen immer mehr Menschen, PHP zur Entwicklung von Webseiten zu verwenden. Wenn wir jedoch eine PHP-Webseite schreiben, kann es zu einem sehr häufigen Problem kommen: Fehler bei Benutzername und Passwort können nicht gelöscht werden.
Das liegt daran, dass wir beim Entwerfen der Anmeldeseite normalerweise den Benutzernamen und das Passwort in der Backend-Datenbank speichern und dann, wenn sich der Benutzer anmeldet, eine HTTP-Anfrage an den Backend-Server senden, um zu überprüfen, ob der Benutzername und das Passwort korrekt sind . Wenn der Benutzername und das Passwort falsch sind, gibt der Server eine entsprechende Fehlermeldung zurück, wir können die Fehlermeldung jedoch nicht zur Anzeige an die Front-End-Schnittstelle zurücksenden.
Also, wie kann man dieses Problem lösen?
Zuerst müssen wir dem Hintergrund-PHP-Skript etwas Code hinzufügen, um Fehlermeldungen zu erfassen. Die spezifische Methode ist wie folgt:
//connect to database $server = "localhost"; $username = "root"; $password = "your_password"; $dbname = "your_database"; $mysqli = new mysqli($server, $username, $password, $dbname); //check connection if ($mysqli->connect_error) { die("Connection failed: " . $mysqli->connect_error); } //process login request $username = $_POST["username"]; $password = $_POST["password"]; $sql = "SELECT * FROM users WHERE username='$username' AND password='$password'"; $result = $mysqli->query($sql); if ($result->num_rows > 0) { //login success echo "Welcome, " . $username . "!"; } else { //login failed echo "Username or password is incorrect."; }
Im obigen Code stellen wir mithilfe der MySQL-Klasse in PHP eine Verbindung zur MySQL-Datenbank her und gleichen den eingegebenen Benutzernamen und das Passwort mit dem Benutzernamen und dem Passwort in der Datenbank ab. Wenn Benutzername und Passwort erfolgreich übereinstimmen, wird eine Willkommensnachricht zurückgegeben, andernfalls wird eine Fehlermeldung zurückgegeben.
Wenn wir jedoch die Anmeldeseite besuchen, kann die Fehlermeldung immer noch nicht auf der Startseite angezeigt werden. Daher müssen wir die AJAX-Technologie verwenden, um Fehlerinformationen vom Back-End-PHP-Skript an die Front-End-Schnittstelle zu übergeben.
Die spezifische Methode lautet wie folgt:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Login Form</title> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script> <script> function login() { var username = $("#username").val(); var password = $("#password").val(); $.post("process_login.php", {username: username, password: password}, function(data) { $("#result").html(data); }); } </script> </head> <body> <h1>Login Form</h1> <form> <label>Username:</label><input type="text" id="username"><br> <label>Password:</label><input type="password" id="password"><br> <button type="button" onclick="login()">Login</button> </form> <div id="result"></div> </body> </html>
Im obigen Code verwenden wir die jQuery-AJAX-Technologie, um den eingegebenen Benutzernamen und das Passwort über eine HTTP-POST-Anfrage an das Hintergrund-PHP-Skript zu senden und die zurückgegebenen Ergebnisse im Frontend anzuzeigen Seite.
Wenn daher der Benutzername und das Passwort falsch eingegeben werden, wird die Fehlermeldung an die Frontend-Seite übertragen, wodurch das Problem gelöst wird, dass wir die Benutzernamen- und Passwortfehler nicht löschen können.
Kurz gesagt, das Obige ist die Lösung zum Löschen falscher Benutzernamen und Passwörter auf PHP-Webseiten. Dies ist eine sehr nützliche Übung für Anfänger, die ihre PHP-Programmierkenntnisse verbessern möchten.
Das obige ist der detaillierte Inhalt vonLassen Sie uns über das Problem des Löschens falscher Benutzernamen und Passwörter auf PHP-Webseiten sprechen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!