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
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;, damit Benutzer ihn nicht im Browser sehen können Der Header hat keinen Einfluss darauf, dass Nginx ihn aufzeichnet.
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!