suchen
HeimDatenbankMySQL-TutorialWie 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 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

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;

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

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;
, 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!

Stellungnahme
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
Was sind die Grenzen der Verwendung von Ansichten in MySQL?Was sind die Grenzen der Verwendung von Ansichten in MySQL?May 14, 2025 am 12:10 AM

MySQLViewShavelimitations: 1) Sie sind supportallsqloperationen, restriktedatamanipulation ThroughviewswithjoinSuBqueries.2) Sie können sich angesehen, insbesondere mit der kompetenten Formata -Ansichten, die docrexQuqueriesorlargedatasets angezeigt werden

Sicherung Ihrer MySQL -Datenbank: Hinzufügen von Benutzern und Gewährung von BerechtigungenSicherung Ihrer MySQL -Datenbank: Hinzufügen von Benutzern und Gewährung von BerechtigungenMay 14, 2025 am 12:09 AM

OrteSermanagementinmysqlisicialforenHancingSecurityAnsuringEffizienceDatabaseoperation.1) Usecreateutertoaddusers, spezifizierende Connections mit 'localhost'or@'%'.

Welche Faktoren beeinflussen die Anzahl der Trigger, die ich in MySQL verwenden kann?Welche Faktoren beeinflussen die Anzahl der Trigger, die ich in MySQL verwenden kann?May 14, 2025 am 12:08 AM

Mysqldoes nicht imposeahardlimitontriggers, aber praktische Faktorendeterminetheireffectiveuse: 1) serverconfigurationImpactstriggermanagement;

MySQL: Ist es sicher, Blob zu speichern?MySQL: Ist es sicher, Blob zu speichern?May 14, 2025 am 12:07 AM

Ja, es ist safetostoreblobdatainmysql, butconsiderthesefactors: 1) StorageSpace: BloBScanconSignificantantspace, potenziellincreaseingCostsandSlowingPerformance.2) Leistung: größereRowsisDuetoBoBsMayslowdownquers.3) BackupandRecovery:

MySQL: Hinzufügen eines Benutzers über eine PHP -Weboberfläche hinzufügenMySQL: Hinzufügen eines Benutzers über eine PHP -Weboberfläche hinzufügenMay 14, 2025 am 12:04 AM

Das Hinzufügen von MySQL -Benutzern über die PHP -Weboberfläche kann MySQLI -Erweiterungen verwenden. Die Schritte lauten wie folgt: 1. Verbinden Sie eine Verbindung zur MySQL -Datenbank und verwenden Sie die MySQLI -Erweiterung. 2. Erstellen Sie einen Benutzer, verwenden Sie die Anweisung createUser und verwenden Sie die Funktion password (), um das Kennwort zu verschlüsseln. 3.. Verhindern Sie die SQL -Injektion und verwenden Sie die Funktion mySQLI_REAL_ESCAPE_STRING (), um die Benutzereingabe zu verarbeiten. V.

MySQL: Blob und andere Nicht-SQL-Speicher, was sind die Unterschiede?MySQL: Blob und andere Nicht-SQL-Speicher, was sind die Unterschiede?May 13, 2025 am 12:14 AM

Mysql'SbloBissableForstoringBinaryDatawithinarelationalDatabase, whilenosqloptionslikemongodb, Redis und CassandraofferFlexible, skalablessolutionenfornernstrukturierteData.blobissimplerbutcanslowdownscalgedlargedDataTTersClaTTersScalgedlargedDataTersClaTTersScalgedlargedDataTersClaTTERSCHITHLARGEGEGEBEN

MySQL Fügen Sie Benutzer hinzu: Syntax-, Optionen und Best Practices für SicherheitsverhältnisseMySQL Fügen Sie Benutzer hinzu: Syntax-, Optionen und Best Practices für SicherheitsverhältnisseMay 13, 2025 am 12:12 AM

ToaddauserinMysql, Verwendung: createUser'username '@' host'identifiedBy'password '; hier'Showtodoitesecurely: 1) choosethehostCrefulyTocon TrolAccess.2) setResourcelimits withOptionslikemax_queries_per_hour.3) UsSeStong, Uniquepasswords.4) Enforcesl/tlsConnectionsWith

MySQL: Wie vermeidet man String -Datentypen gemeinsame Fehler?MySQL: Wie vermeidet man String -Datentypen gemeinsame Fehler?May 13, 2025 am 12:09 AM

ToavoidCommonMistakeswithStringDatatypesinmysql, Verständnisstringtypenuances, ChoosetherightType, und ManageCodingandCollationsetingseffekt.1) UsecharforFixed-Länge-Strings, Varcharforvariable-Länge und Ventionlargerdata.2) -Tetcorrectaracters und Ventionlargerdata.2)

See all articles

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

Nordhold: Fusionssystem, erklärt
4 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
Mandragora: Flüstern des Hexenbaum
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

SublimeText3 Linux neue Version

SublimeText3 Linux neue Version

SublimeText3 Linux neueste Version

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

VSCode Windows 64-Bit-Download

VSCode Windows 64-Bit-Download

Ein kostenloser und leistungsstarker IDE-Editor von Microsoft

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)