[PHP]代碼 ?
<?php // 為php和mysql剔除不安全html代碼。 //http://www.miracleart.cn/ function safestrip($string){ $string = strip_tags($string); $string = mysql_real_escape_string($string); return $string; } //登錄信息顯示函數 function messages() { $message = ''; if($_SESSION['success'] != '') { $message = '<span id="message">' .$_SESSION['success'].'</span>'; $_SESSION['success'] = ''; } if($_SESSION['error'] != '') { $message = '<span id="message">' .$_SESSION['error'].'</span>'; $_SESSION['error'] = ''; } return $message; } // 用戶登錄函數 function login($username, $password){ //過濾用戶輸入的用戶名和密碼 $user = safestrip($username); $pass = safestrip($password); //將密碼轉換為md5格式 $pass = md5($pass); // 查詢數據庫中用戶名和密碼是否匹配 $sql = mysql_query("SELECT * FROM user_table WHERE username = '$user' AND password = '$pass'")or die(mysql_error()); //如果=1則表示認證成功 if (mysql_num_rows($sql) == 1) { //開始記錄在session中 $_SESSION['authorized'] = true; // 重新加載頁面 $_SESSION['success'] = '登錄成功'; header('Location: ./index.php'); exit; } else { // 登錄失敗記錄在session中 $_SESSION['error'] = '非常抱歉,您輸入的用戶名或密碼有誤'; } } ?>
? ? ? ? ? ? ? ? ? ?
? ? ? ? ? ? ? ? ? ?

Hei?e KI -Werkzeuge

Undress AI Tool
Ausziehbilder kostenlos

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem v?llig kostenlosen KI-Gesichtstausch-Tool aus!

Hei?er Artikel

Hei?e Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Hei?e Themen

STD :: CHRONO wird in C verwendet, um die Zeit zu verarbeiten, einschlie?lich des Erhaltens der aktuellen Zeit, der Messung der Ausführungszeit, der Betriebszeit und -dauer und der Formatierungsanalysezeit. 1. Verwenden Sie std :: chrono :: system_clock :: Now (), um die aktuelle Zeit zu erhalten, die in eine lesbare Zeichenfolge konvertiert werden kann, aber die Systemuhr ist jedoch m?glicherweise nicht eint?nig. 2. Verwenden Sie STD :: Chrono :: Steady_clock, um die Ausführungszeit zu messen, um die Monotonie zu gew?hrleisten, und umwandeln Sie sie durch Duration_cast in Millisekunden, Sekunden und andere Einheiten; 3. Zeitpunkt (Time_Point) und Dauer (Dauer) k?nnen interoperabel sein, aber die Aufmerksamkeit der Einheitenkompatibilit?t und der Uhr -Epoche (Epoche) sollte beachtet werden.

ToaccessesvironmentvariableSinphp, useGetEnv () orthe _envSuperglobal.1.getenv ('var_name') ruftaspecificVariable.2. $ _ EN V ['var_name'] AccessesVariablesifvariables_OrderInphp.iniincludes "e" .setvariablesviacliwithvar = ValuePhpScript.php, Inapach

Gründe und L?sungen für den Sprungversagen der Header-Funktion: 1. Vor dem Header gibt es Ausgabe, und alle Vorg?nger müssen überprüft und entfernt werden oder obs_start () Puffer wird verwendet. 2. Das Vers?umnis, Exit hinzuzufügen, führt zu einer nachfolgenden Code -Interferenz, und das Beenden oder die Sterbe sollte unmittelbar nach dem Sprung hinzugefügt werden. 3. Der Pfadfehler sollte verwendet werden, um die Korrektheit durch die Verwendung absoluter Pfade oder dynamisches Splei?en zu gew?hrleisten. 4. Serverkonfiguration oder Cache -Interferenz kann versucht werden, den Cache zu l?schen oder den Umgebungstest zu ersetzen.

Die Methode zur Verwendung von Vorverarbeitungsanweisungen, um die Datenbankabfrage zu erhalten, führt zu PHP von der Erweiterung. 1. Bei der Verwendung von MySQLI k?nnen Sie das assoziative Array über Get_Result () und fetch_assoc () erhalten, was für moderne Umgebungen geeignet ist. 2. Sie k?nnen auch Bind_result () verwenden, um Variablen zu binden, was für Situationen geeignet ist, in denen es nur wenige Felder und feste Strukturen gibt, und es ist eine gute Kompatibilit?t, aber es gibt viele Felder, wenn es viele Felder gibt. 3. Bei Verwendung von PDO k?nnen Sie das assoziative Array über Fetch (pdo :: fetch_assoc) erhalten oder Fetchall () gleichzeitig erhalten, damit die Schnittstelle einheitlich ist und die Fehlerbehandlung klarer ist. Darüber hinaus müssen Sie auf die Parametertyp -übereinstimmung, die Ausführung von Execute (), die rechtzeitige Ver?ffentlichung von Ressourcen und die Aktivierung von Fehlerberichten achten.

In PHP k?nnen Sie eine Vielzahl von Methoden verwenden, um festzustellen, ob eine Zeichenfolge mit einer bestimmten Zeichenfolge beginnt: 1. Verwenden Sie Strncmp (), um die ersten N -Zeichen zu vergleichen. Wenn 0 zurückgegeben wird, passt der Anfang überein und sind nicht sensibel; 2. Verwenden Sie Strpos (), um zu prüfen, ob die Substringposition 0 ist, was für Fall empfindlich ist. Stripos () kann stattdessen verwendet werden, um Fall unempfindlich zu erreichen; 3.. Sie k?nnen die Funktion startsWith () oder str_starts_with () zusammenschlie?en, um die Wiederverwendbarkeit zu verbessern. Darüber hinaus ist zu beachten, dass leere Zeichenfolgen standardm??ig true, codierende Kompatibilit?ts- und Leistungsunterschiede, sTRNCMP () in der Regel effizienter.

Es gibt drei wichtige M?glichkeiten, um den Fehler "undefinedIndex" zu vermeiden: Verwenden Sie zun?chst ISSET (), um zu überprüfen, ob der Array -Schlüssel existiert, und sicherzustellen, dass der Wert nicht null ist, was für die meisten gemeinsamen Szenarien geeignet ist. Zweitens verwenden Sie Array_key_exists (), um nur zu bestimmen, ob der Schlüssel vorhanden ist, was für Situationen geeignet ist, in denen der Schlüssel nicht existiert und der Wert null ist. Verwenden Sie schlie?lich den leeren Merge -Operator? (Php7) Um den für modernen PHP -Projekte empfohlenen Standardwert genau festzulegen und auf die Schreibweise der Feldnamen des Formulars zu achten, verwenden Sie extract () und überprüfen Sie, ob das Array nicht leer ist, bevor Sie durchqueren, um Risiken weiter zu vermeiden.

Bei Verwendung von PHP -Vorverarbeitungsanweisungen zur Ausführung von Abfragen mit in Klauseln erzeugen 1. dynamisch Platzhalter gem?? der L?nge des Arrays; 2. Wenn Sie PDO verwenden, k?nnen Sie das Array direkt übergeben und Array_values verwenden, um kontinuierliche Indizes zu gew?hrleisten. 3. Bei Verwendung von MySQLI müssen Sie Typ -Zeichenfolgen konstruieren und Parameter binden, auf die Art und Weise achten, die Kompatibilit?t von Array und Version zu erweitern. 4. Vermeiden Sie das Splei?en von SQL, die Verarbeitung leerer Arrays und stellen Sie sicher, dass Datentypen übereinstimmen. Die spezifische Methode ist: Verwenden Sie zuerst Implode und Array_Fill, um Platzhalter zu generieren, und binden dann Parameter nach den erweiterten Eigenschaften, um in Abfragen sicher auszuführen.
