Heim  >  Artikel  >  Datenbank  >  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?

黄舟
黄舟Original
2017-07-21 16:32:331358Durchsuche

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