Heim Datenbank MySQL-Tutorial Wie zeichnet man die Benutzer-ID in MySQL mithilfe des Nginx-Zugriffsprotokolls auf?

Wie zeichnet man die Benutzer-ID in MySQL mithilfe des Nginx-Zugriffsprotokolls auf?

Jul 21, 2017 pm 04:32 PM
mysql 使用 如何

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"
Nach dem Login kopieren

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);
}
Nach dem Login kopieren

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 &#39;$remote_addr - $upstream_http_x_uid [$time_local] "$request" $status $body_bytes_sent "$http_referer" "$http_user_agent"&#39;;
Nach dem Login kopieren

Beziehen Sie sich auf dieses Protokollformat im Server

Da wir in den serverbezogenen Einstellungen das Protokollformat vorne benannt haben, zitieren wir es hier. Wenn Sie das vordere Protokollformat angeben müssen:


access_log /var/log/nginx/front-access.log front;
Nach dem Login kopieren

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"
Nach dem Login kopieren

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

Im ersten Schritt oben haben wir PHP verwendet, um einen speziellen Header auszugeben hatte dies Der Header ist nur für den Verbrauch durch Nginx bestimmt, aber dieser Header wird von Nginx intakt im Frontend angezeigt, was bei vorsichtigen Benutzern zu Unbehagen führen kann. Aus diesem Grund können wir in den Nginx-Servereinstellungen einen kleinen Schalter hinzufügen, um diesen Header auszublenden:


proxy_hide_header X-UID;
Nach dem Login kopieren
, damit Benutzer ihn nicht im Browser sehen können Der Header hat keinen Einfluss darauf, dass Nginx ihn aufzeichnet.

Endbearbeitung

Was bringt es also, dass wir so viel Mühe aufwenden, um einen Ausweis zu erfassen? Das ist von großem Nutzen. Jeder weiß, dass wir mit Logstash über ein leistungsstarkes Tool zur Protokollanalyse verfügen, mit dem sich in Kombination mit der ELK-Komponente Apache- oder Nginx-Protokolle analysieren und verarbeiten lassen. Wenn wir diese ID-Informationen nicht haben, können wir nur analysieren, welche Webseiten von Benutzern häufig besucht werden, und das war's. Aber jetzt, da wir Benutzer-IDs haben, können wir uns zur Analyse sogar mit der MySQL-Datenbanktabelle verbinden, um zu untersuchen, welche Altersgruppe, welches Geschlecht oder welche Stadt Benutzer welche Webseiten gerne besuchen, und sogar gezielt einen bestimmten Benutzer verstehen , welche Webseiten sie zu welchem ​​Zeitpunkt gerne besuchen und ihnen dann gezielt maßgeschneiderte Dienste anbieten. Ist das nicht stark genug?

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!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

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

Heißer Artikel

<🎜>: Bubble Gum Simulator Infinity - So erhalten und verwenden Sie Royal Keys
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Fusionssystem, erklärt
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Flüstern des Hexenbaum
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Java-Tutorial
1665
14
PHP-Tutorial
1270
29
C#-Tutorial
1249
24
Beispiel für Laravel -Einführung Beispiel für Laravel -Einführung Apr 18, 2025 pm 12:45 PM

Laravel ist ein PHP -Framework zum einfachen Aufbau von Webanwendungen. Es bietet eine Reihe leistungsstarker Funktionen, darunter: Installation: Installieren Sie die Laravel CLI weltweit mit Komponisten und erstellen Sie Anwendungen im Projektverzeichnis. Routing: Definieren Sie die Beziehung zwischen der URL und dem Handler in Routen/Web.php. Ansicht: Erstellen Sie eine Ansicht in Ressourcen/Ansichten, um die Benutzeroberfläche der Anwendung zu rendern. Datenbankintegration: Bietet eine Out-of-the-Box-Integration in Datenbanken wie MySQL und verwendet Migration, um Tabellen zu erstellen und zu ändern. Modell und Controller: Das Modell repräsentiert die Datenbankentität und die Controller -Prozesse HTTP -Anforderungen.

MySQL und PhpMyAdmin: Kernfunktionen und Funktionen MySQL und PhpMyAdmin: Kernfunktionen und Funktionen Apr 22, 2025 am 12:12 AM

MySQL und PhpMyAdmin sind leistungsstarke Datenbankverwaltungs -Tools. 1) MySQL wird verwendet, um Datenbanken und Tabellen zu erstellen und DML- und SQL -Abfragen auszuführen. 2) PHPMYADMIN bietet eine intuitive Schnittstelle für Datenbankverwaltung, Tabellenstrukturverwaltung, Datenoperationen und Benutzerberechtigungsverwaltung.

MySQL gegen andere Programmiersprachen: Ein Vergleich MySQL gegen andere Programmiersprachen: Ein Vergleich Apr 19, 2025 am 12:22 AM

Im Vergleich zu anderen Programmiersprachen wird MySQL hauptsächlich zum Speichern und Verwalten von Daten verwendet, während andere Sprachen wie Python, Java und C für die logische Verarbeitung und Anwendungsentwicklung verwendet werden. MySQL ist bekannt für seine hohe Leistung, Skalierbarkeit und plattformübergreifende Unterstützung, die für Datenverwaltungsanforderungen geeignet sind, während andere Sprachen in ihren jeweiligen Bereichen wie Datenanalysen, Unternehmensanwendungen und Systemprogramme Vorteile haben.

Lösen Sie das Datenbankverbindungsproblem: Ein praktischer Fall der Verwendung von Minii/DB -Bibliothek Lösen Sie das Datenbankverbindungsproblem: Ein praktischer Fall der Verwendung von Minii/DB -Bibliothek Apr 18, 2025 am 07:09 AM

Bei der Entwicklung einer kleinen Anwendung stieß ich auf ein kniffliges Problem: die Notwendigkeit, eine leichte Datenbankbetriebsbibliothek schnell zu integrieren. Nachdem ich mehrere Bibliotheken ausprobiert hatte, stellte ich fest, dass sie entweder zu viel Funktionalität haben oder nicht sehr kompatibel sind. Schließlich fand ich Minii/DB, eine vereinfachte Version basierend auf YII2, die mein Problem perfekt löste.

Laravel Framework Installationsmethode Laravel Framework Installationsmethode Apr 18, 2025 pm 12:54 PM

Artikelzusammenfassung: Dieser Artikel enthält detaillierte Schritt-für-Schritt-Anweisungen, um die Leser zu leiten, wie das Laravel-Framework einfach installiert werden kann. Laravel ist ein leistungsstarkes PHP -Framework, das den Entwicklungsprozess von Webanwendungen beschleunigt. Dieses Tutorial deckt den Installationsprozess von den Systemanforderungen bis zur Konfiguration von Datenbanken und das Einrichten von Routing ab. Durch die Ausführung dieser Schritte können die Leser schnell und effizient eine solide Grundlage für ihr Laravel -Projekt legen.

Lösen Lösen Apr 18, 2025 am 08:42 AM

Bei der Entwicklung einer E-Commerce-Website mit Thelia habe ich auf ein kniffliges Problem gestoßen: Der MySQL-Modus ist nicht ordnungsgemäß eingestellt, wodurch einige Funktionen nicht ordnungsgemäß funktionieren. Nach einigen Erkundungen fand ich ein Modul namens TheliamysqlModeSCecker, das das von Thelia erforderliche MySQL -Muster automatisch beheben kann und meine Probleme vollständig lösen kann.

MySQL: Strukturierte Daten und relationale Datenbanken MySQL: Strukturierte Daten und relationale Datenbanken Apr 18, 2025 am 12:22 AM

MySQL verwaltet strukturierte Daten effizient durch Tabellenstruktur und SQL-Abfrage und implementiert Inter-Tisch-Beziehungen durch Fremdschlüssel. 1. Definieren Sie beim Erstellen einer Tabelle das Datenformat und das Typ. 2. Verwenden Sie fremde Schlüssel, um Beziehungen zwischen Tabellen aufzubauen. 3.. Verbessern Sie die Leistung durch Indexierung und Abfrageoptimierung. 4. regelmäßig Sicherung und Überwachung von Datenbanken, um die Datensicherheit und die Leistungsoptimierung der Daten zu gewährleisten.

MySQL: Schlüsselmerkmale und Funktionen erklärt MySQL: Schlüsselmerkmale und Funktionen erklärt Apr 18, 2025 am 12:17 AM

MySQL ist ein Open Source Relational Database Management -System, das in der Webentwicklung häufig verwendet wird. Zu den wichtigsten Funktionen gehören: 1. unterstützt mehrere Speichermotoren wie InnoDB und MyISAM, geeignet für verschiedene Szenarien; 2. Bietet Master-Slave-Replikationsfunktionen, um Lastausgleich und Datensicherung zu erleichtern. 3.. Verbessern Sie die Abfrageeffizienz durch Abfrageoptimierung und Index.

See all articles