用PHP MySQL搭建聊天室
Jun 08, 2016 pm 05:33 PMMySQL并發(fā)能力強、響應(yīng)速度快,是性能優(yōu)異的數(shù)據(jù)庫軟件;PHP是功能強大的服務(wù)器端腳本語言。筆者在山西鋁廠網(wǎng)站開發(fā)中,采用PHP4.0 MySQL3.23.38建立了多種應(yīng)用。下面,以一個簡單的聊天室設(shè)計為例,介紹PHP MySQL在網(wǎng)頁開發(fā)中的應(yīng)用。
1、總體設(shè)計
1.1 構(gòu)思與規(guī)劃:
聊天室的基本原理,就是把每個連上同一網(wǎng)頁的用戶傳送的發(fā)言數(shù)據(jù)儲存起來,然后將所有的發(fā)言數(shù)據(jù)傳給每一用戶。也就是說,用數(shù)據(jù)庫匯集每個人的發(fā)言,并將數(shù)據(jù)庫中的數(shù)據(jù)傳給每一個人就實現(xiàn)了聊天室的功能。
1.2 表設(shè)計
首先使用MySQL建立表chat用來儲存用戶的發(fā)言:
mysql> CREATE TABLE chat
-> (chtime DATATIME,
-> nick CHAR(10) NOT NULL,
->words CHAR(150));
表中只設(shè)定了三個域,chtime是發(fā)言的時間,nick為發(fā)言者的昵稱,words是發(fā)言的內(nèi)容,發(fā)言最多150個字符
1.3 網(wǎng)頁設(shè)計
一個最簡單的聊天室通常需要兩個頁框:一個頁框是用戶輸入發(fā)言的表單,另一個用來顯示大家的發(fā)言。所以代碼段通常至少需要如下幾段:
建立頁框的結(jié)構(gòu)(main.php)
顯示大家發(fā)言的程序段(cdisplay.php)
傳送用戶發(fā)言的程序段(speak.php)
用戶登錄進入聊天室程序段(login.php)
2、代碼設(shè)計
以上規(guī)劃完成后,就可以著手代碼設(shè)計了,采用php可以非常簡明實現(xiàn)以上的功能。
2.1 用戶登錄login.php,本段代碼是一個完全HTML網(wǎng)頁
請輸入您的昵稱

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

Um PHP -Datei -Uploads sicher zu verarbeiten, müssen Sie die Quelle und die Type und die Eingabe des Dateinamens und des Pfades überprüfen, Serverbeschr?nkungen festlegen und Mediendateien zweimal verarbeiten. 1. überprüfen Sie die Upload -Quelle, um CSRF durch Token zu verhindern, und erkennen Sie den realen MIME -Typ über die Finfo_file mithilfe der Whitelist -Steuerung. 2. Benennen Sie die Datei in eine zuf?llige Zeichenfolge um und bestimmen Sie die Erweiterung, um sie gem?? dem Erkennungstyp in einem Verzeichnis ohne Web zu speichern. 3. Die PHP -Konfiguration begrenzt die Hochladengr??e und das tempor?re Verzeichnis Nginx/Apache verbietet den Zugriff auf das Upload -Verzeichnis. 4. Die GD -Bibliothek stellt die Bilder neu, um potenzielle b?swillige Daten zu l?schen.

Inphp, variablenArepassedByValuebyDefault, BedeutungFunctionsSignmentsRecepeacopyofthedata, whilepassingyreferenceAllowsModificationStoeTheoriginalVariable.1.Weit PassingByValue, Changestothecopydonottheoriginal, Asshown, Asshown, $ b = $ -Pectheoriginal, Asshown, $ $ -Pectheoriginal, Asshown, $ organ

Der direkteste Weg, um das letzte Auftreten eines Substring in PHP zu finden, besteht darin, die Funktion von Strrpos () zu verwenden. 1. Verwenden Sie die Funktion von Strrpos (), um den Index des letzten Auftretens des Substring in der Hauptzeichenfolge direkt zu erhalten. Wenn es nicht gefunden wird, gibt es falsch zurück. Die Syntax ist strrpos ($ haystack, $ nadle, $ offset = 0). 2. Wenn Sie den Fall ignorieren müssen, k?nnen Sie die Funktion von Strripos () verwenden, um die von Fall unempfindliche Suche zu implementieren. 3.. Für Multi-Byte-Zeichen wie Chinese sollte die Funktion mb_strrpos () in der Mbstring-Erweiterung verwendet werden, um sicherzustellen, dass die Zeichenposition anstelle der Byte-Position zurückgegeben wird. 4. Beachten Sie, dass Strrpos () f zurückkehrt

MySQL unterstützt die Transaktionsverarbeitung und verwendet die InnoDB Storage Engine, um die Datenkonsistenz und Integrit?t zu gew?hrleisten. 1. Transaktionen sind eine Reihe von SQL -Operationen, entweder alle erfolgreich oder alle nicht zurückrollen. 2. S?ureattribute umfassen Atomizit?t, Konsistenz, Isolation und Persistenz; 3. Die Aussagen, die Transaktionen manuell kontrollieren, sind Starttransaktion, Commit und Rollback; V. 5. Verwenden Sie die Transaktionen korrekt, um den langfristigen Betrieb zu vermeiden, automatische Commits auszuschalten und Verriegelungen und Ausnahmen vernünftig zu verarbeiten. Durch diese Mechanismen kann MySQL eine hohe Zuverl?ssigkeit und eine gleichzeitige Kontrolle erreichen.

Die Probleme mit dem Charaktersatz und Sortieren von Regeln sind h?ufig, wenn plattformübergreifende Migration oder mehrk?pfige Entwicklung entwickelt werden, was zu verstümmelten Code oder inkonsistenten Abfragen führt. Es gibt drei Kernl?sungen: überprüfen und vereinbaren Sie zun?chst den Zeichensatz von Datenbank, Tabelle und Feldern in UTF8MB4, sehen Sie sich durch showCreateDatabase/Tabelle an und ?ndern Sie sie mit Alter Anweisung. Zweitens geben Sie das UTF8MB4 -Zeichen fest, wenn der Client eine Verbindung herstellt, und setzen Sie ihn in Verbindungsparametern oder setzen Sie SetNames aus. W?hlen Sie drittens die Sortierregeln vernünftig aus und empfehlen Sie die Verwendung von UTF8MB4_unicode_ci, um die Genauigkeit von Vergleich und Sortierung zu gew?hrleisten, und geben Sie sie beim Erstellen der Bibliothek und der Tabelle an.

Die direkteste M?glichkeit, eine Verbindung zur MySQL -Datenbank herzustellen, besteht darin, den Befehlszeilenclient zu verwenden. Geben Sie zun?chst den MySQL -U -Benutzernamen -P ein und geben Sie das Passwort korrekt ein, um die interaktive Schnittstelle einzugeben. Wenn Sie eine Verbindung zur Remote -Datenbank herstellen, müssen Sie den Parameter -H hinzufügen, um die Host -Adresse anzugeben. Zweitens k?nnen Sie direkt zu einer bestimmten Datenbank wechseln oder SQL-Dateien ausführen

Der Grund, warum der Header ('Ort: ...') in der AJAX -Anforderung ungültig ist, ist, dass der Browser nicht automatisch die Seitenleiter ausführt. Denn in der AJAX -Anforderung werden die vom Server zurückgegebenen Statuscode und Standort -Header -Informationen als Antwortdaten verarbeitet, anstatt das Sprungverhalten auszul?sen. L?sungen sind: 1. Return JSON -Daten in PHP und enthalten eine Sprung -URL; 2. überprüfen Sie das Umleitungsfeld im Front-End-Ajax-Rückruf und springen Sie manuell mit window.location.href; 3. Stellen Sie sicher, dass der PHP -Ausgang nur JSON ist, um das Analysen eines Ausfalls zu vermeiden. 4. Um mit Cross-Dom?nen-Problemen umzugehen, müssen Sie geeignete CORS-Header einstellen. 5. Um Cache -Interferenzen zu verhindern, k?nnen Sie einen Zeitstempel hinzufügen oder Cache einstellen: F.

Die Einstellung von Zeichens?tzen und Kollationsregeln in MySQL ist entscheidend und beeinflusst die Datenspeicherung, die Abfrageeffizienz und -konsistenz. Erstens bestimmt der Charakter -Set den aufbewahrbaren Charakterbereich, wie beispielsweise UTF8MB4 Chinesisch und Emojis unterstützt. Die Sortierregeln steuern die Zeichenvergleichsmethode wie UTF8MB4_Unicode_CI, und UTF8MB4_BIN ist ein bin?rer Vergleich. Zweitens kann der Zeichensatz auf mehrere Server-, Datenbank-, Tabellen- und Spaltenstufen festgelegt werden. Es wird empfohlen, UTF8MB4 und UTF8MB4_Unicode_ci auf einheitliche Weise zu verwenden, um Konflikte zu vermeiden. Darüber hinaus wird das Problem der verstümmelten Code h?ufig durch inkonsistente Zeichens?tze von Verbindungen, Speicher- oder Programmanschlüssen verursacht und muss Schicht für Schicht überprüft und einheitlich eingestellt werden. Zus?tzlich sollten Zeichens?tze beim Exportieren und Importieren angegeben werden, um Konversionsfehler zu verhindern
