


Wie zeichnet man die Benutzer-ID in MySQL mithilfe des Nginx-Zugriffsprotokolls auf?
Dieser Artikel führt Sie hauptsächlich in die relevanten Informationen zur Verwendung von Nginx-Zugriffsprotokollen zum Aufzeichnen von Benutzer-IDs in MySQL ein. Der Artikel bietet einen gewissen Referenz-Lernwert für jedermann wird benötigt Freunde, bitte folgen Sie dem Herausgeber, um gemeinsam zu lernen.
Vorwort
Jeder sollte wissen, dass Nginx über eine sehr leistungsstarke Protokollierungsfunktion verfügt, aber standardmäßig nur die IP-Adresse und den Browser des Benutzers protokollieren kann Information. Wenn sich ein Benutzer beim Registrierungssystem anmeldet und der Benutzer bereits angemeldet ist, möchten wir aufzeichnen, welcher Benutzer eine bestimmte Webseite besucht hat. Was sollen wir tun? Denn wir möchten nicht nur wissen, welche IP-Adresse welche Webseite besucht hat, sondern auch, welcher angemeldete Benutzer welche Webseite besucht hat. Dies wird uns helfen, ihm/ihr in Zukunft gezielt Werbung zu empfehlen nützlich. Im Folgenden gibt es nicht viel zu sagen. Werfen wir einen Blick auf die ausführliche Einführung:
Nginx-Standardprotokollformat
127.0.0.1 - - [20/Jul/2017:22:04:08 +0800] "GET /news/index HTTP/1.1" 200 22262 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/60.0.3112.66 Safari/537.36"
Hier sehen wir, dass sich der Benutzer zwar angemeldet hat, im Protokoll jedoch keine benutzerbezogenen Informationen enthalten sind, sondern nur die IP-Adresse. Was sollen wir tun, wenn wir die Benutzer-ID und andere Informationen aufzeichnen möchten?
Geben Sie einen speziellen Header auf der PHP-Seite aus
Wir dachten, dass der Benutzer, da er sich angemeldet hat, ein Cookie haben muss oder Sitzung Oder Token-Informationen, egal auf welche Weise, unser PHP kann die Informationen des Benutzers effektiv abrufen. Hier erhalten wir beispielsweise die ID-Informationen des Benutzers über die Sitzung:
$user_id = Yii::$app->session['user_id']; if (empty($user_id)) { header('X-UID: 0'); } else { header('X-UID: ' . $user_id); }
Wenn in der Sitzung keine Benutzer-ID vorhanden ist, bedeutet dies, dass sich der Benutzer nicht angemeldet hat in, und die X-UID wird ausgegeben: 0 (oder Sie können einfach nichts ausgeben). Wenn die Sitzung erhalten wird, bedeutet dies, dass der Benutzer angemeldet ist. Anschließend geben wir seine Benutzer-ID in der Form nginx: X-UID: 12345
aus.
Hier können Sie nicht nur eine Information ausgeben, sondern mehrere verschiedene Felder, darunter seinen Namen, sein Geschlecht, sein Alter usw.
Erstellen Sie ein neues Protokollformat
log_format kann nur im http-Segment gespeichert werden, daher müssen wir nginx conf finden Datei.
Der zweite Teil des Standardprotokollformats von nginx sind Benutzerinformationen, aber normalerweise gibt es nichts, nur ein -. Hier wandeln wir es in die Header-Informationen um, die wir vom Backend übergeben. Der spezielle Header, den wir oben erstellt haben, ist X-UID. Hier müssen wir zuerst eine kleine Konvertierung durchführen, alle Großbuchstaben in Kleinbuchstaben ändern, alles in Unterstriche ändern, es wird zu x_uid, und dann < vor 🎜> zusammenfügen, erhalten Sie das Endergebnis $upstream_http_
und fügen Sie es dann an der gewünschten Stelle in das Protokollformat ein: $upstream_http_x_uid
log_format front '$remote_addr - $upstream_http_x_uid [$time_local] "$request" $status $body_bytes_sent "$http_referer" "$http_user_agent"';
Beziehen Sie sich auf dieses Protokollformat im Server
access_log /var/log/nginx/front-access.log front;
Neues Protokollergebnis
127.0.0.1 - 52248 [20/Jul/2017:22:35:40 +0800] "GET /news/view?id=56 HTTP/1.1" 200 19455 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/60.0.3112.66 Safari/537.36"
Hinweis: Die zweite Zahl oben ist 52248, die persönliche ID unseres angemeldeten Benutzers. Mein Beispiel hier ist relativ einfach. Wenn Ihnen die Mühe nichts ausmacht, können Sie sogar alle persönlichen Informationen des angemeldeten Benutzers, einschließlich Mobiltelefonnummer und E-Mail-Adresse, im Protokoll ausdrucken über Sicherheitsthemen.
Die ID vor dem Benutzer verbergen
proxy_hide_header X-UID;
Endbearbeitung
Zusammenfassung
Das obige ist der detaillierte Inhalt vonWie zeichnet man die Benutzer-ID in MySQL mithilfe des Nginx-Zugriffsprotokolls auf?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

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

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

Undress AI Tool
Ausziehbilder kostenlos

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

Sie können PhpMyAdmin in den folgenden Schritten öffnen: 1. Melden Sie sich beim Website -Bedienfeld an; 2. Finden und klicken Sie auf das Symbol phpmyadmin. 3. Geben Sie MySQL -Anmeldeinformationen ein; 4. Klicken Sie auf "Login".

MySQL ist ein Open Source Relational Database Management -System, das hauptsächlich zum schnellen und zuverlässigen Speicher und Abrufen von Daten verwendet wird. Sein Arbeitsprinzip umfasst Kundenanfragen, Abfragebedingungen, Ausführung von Abfragen und Rückgabergebnissen. Beispiele für die Nutzung sind das Erstellen von Tabellen, das Einsetzen und Abfragen von Daten sowie erweiterte Funktionen wie Join -Operationen. Häufige Fehler umfassen SQL -Syntax, Datentypen und Berechtigungen sowie Optimierungsvorschläge umfassen die Verwendung von Indizes, optimierte Abfragen und die Partitionierung von Tabellen.

Die Position von MySQL in Datenbanken und Programmierung ist sehr wichtig. Es handelt sich um ein Open -Source -Verwaltungssystem für relationale Datenbankverwaltung, das in verschiedenen Anwendungsszenarien häufig verwendet wird. 1) MySQL bietet effiziente Datenspeicher-, Organisations- und Abruffunktionen und unterstützt Systeme für Web-, Mobil- und Unternehmensebene. 2) Es verwendet eine Client-Server-Architektur, unterstützt mehrere Speichermotoren und Indexoptimierung. 3) Zu den grundlegenden Verwendungen gehören das Erstellen von Tabellen und das Einfügen von Daten, und erweiterte Verwendungen beinhalten Multi-Table-Verknüpfungen und komplexe Abfragen. 4) Häufig gestellte Fragen wie SQL -Syntaxfehler und Leistungsprobleme können durch den Befehl erklären und langsam abfragen. 5) Die Leistungsoptimierungsmethoden umfassen die rationale Verwendung von Indizes, eine optimierte Abfrage und die Verwendung von Caches. Zu den Best Practices gehört die Verwendung von Transaktionen und vorbereiteten Staten

MySQL wird für seine Leistung, Zuverlässigkeit, Benutzerfreundlichkeit und Unterstützung der Gemeinschaft ausgewählt. 1.MYSQL bietet effiziente Datenspeicher- und Abruffunktionen, die mehrere Datentypen und erweiterte Abfragevorgänge unterstützen. 2. Übernehmen Sie die Architektur der Client-Server und mehrere Speichermotoren, um die Transaktion und die Abfrageoptimierung zu unterstützen. 3. Einfach zu bedienend unterstützt eine Vielzahl von Betriebssystemen und Programmiersprachen. V.

Apache verbindet eine Verbindung zu einer Datenbank erfordert die folgenden Schritte: Installieren Sie den Datenbanktreiber. Konfigurieren Sie die Datei web.xml, um einen Verbindungspool zu erstellen. Erstellen Sie eine JDBC -Datenquelle und geben Sie die Verbindungseinstellungen an. Verwenden Sie die JDBC -API, um über den Java -Code auf die Datenbank zuzugreifen, einschließlich Verbindungen, Erstellen von Anweisungen, Bindungsparametern, Ausführung von Abfragen oder Aktualisierungen und Verarbeitungsergebnissen.

Der Prozess des Startens von MySQL in Docker besteht aus den folgenden Schritten: Ziehen Sie das MySQL -Image zum Erstellen und Starten des Containers an, setzen

Die Hauptaufgabe von MySQL in Webanwendungen besteht darin, Daten zu speichern und zu verwalten. 1.Mysql verarbeitet effizient Benutzerinformationen, Produktkataloge, Transaktionsunterlagen und andere Daten. 2. Durch die SQL -Abfrage können Entwickler Informationen aus der Datenbank extrahieren, um dynamische Inhalte zu generieren. 3.Mysql arbeitet basierend auf dem Client-Server-Modell, um eine akzeptable Abfragegeschwindigkeit sicherzustellen.

Die Installation von MySQL auf CentOS umfasst die folgenden Schritte: Hinzufügen der entsprechenden MySQL Yum -Quelle. Führen Sie den Befehl mySQL-server aus, um den MySQL-Server zu installieren. Verwenden Sie den Befehl mySQL_SECURE_INSTALLATION, um Sicherheitseinstellungen vorzunehmen, z. B. das Festlegen des Stammbenutzerkennworts. Passen Sie die MySQL -Konfigurationsdatei nach Bedarf an. Tune MySQL -Parameter und optimieren Sie Datenbanken für die Leistung.
