nginxアクセスログを使用してmysqlにユーザーIDを記録するにはどうすればよいですか?
この記事では、nginx アクセス ログを使用して mysql にユーザー ID を記録する方法について、サンプル コードを通じて詳細に紹介します。この記事は、学習や仕事に必要なすべての人の参考になります。以下のエディタで学習してみましょう。
前書き
nginx には非常に強力なログ機能があることは誰もが知っているはずですが、デフォルトではユーザーの IP アドレスとブラウザー情報しか記録できません。ユーザーを登録システムにログインさせ、そのユーザーがすでにログインしている場合、どのユーザーが特定の Web ページにアクセスしたかを記録したい場合、どうすればよいでしょうか?なぜなら、どの IP アドレスがどの Web ページにアクセスしたかだけでなく、どのログイン ユーザーがどの Web ページにアクセスしたかを知りたいからです。これは、将来、情報を推奨したり、ターゲットを絞った方法でそのユーザーに広告をプッシュしたりするのに役立ちます。役に立つ。これ以上の苦労はせずに、詳細な紹介を見てみましょう:
nginx のデフォルトのログ形式
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"
ここでは、ユーザーがログインしているにもかかわらず、ログには何もないことがわかります。ユーザーに関する情報はIPアドレスです。ユーザーIDなどの情報を記録したい場合はどうすればよいですか?
PHP側で特別なヘッダーを出力します
ユーザーがログインしているので、どの方法であっても、私たちのphpは有効である必要があると考えました。このユーザーの情報を取得します。情報。以下はセッションを通じてユーザーの ID 情報を取得する例です:
$user_id = Yii::$app->session['user_id']; if (empty($user_id)) { header('X-UID: 0'); } else { header('X-UID: ' . $user_id); }
セッションにユーザー ID がない場合は、ユーザーがログインしていないことを意味し、X-UID: 0 (または単に何も出力しないこともできます)。セッションが取得された場合は、ユーザーがログインしたことを意味し、その user_id を nginx: X-UID: 12345
の形式で出力します。 nginx: X-UID: 12345
这样的形式。
在这里,你不止可以输出一个信息,你可以输出好几个不同的字段,包括他的姓名、性别、年龄等等都可以。
创建一种新的日志格式
log_format只能被存储在http段里,所以我们需要找到nginx.conf文件。
nginx缺省的日志格式第二部分就是用户信息,但通常什么也没有,只是一个-,这里我们它改造成我们从后端传进来的header信息。由上文我们创造的特殊header是X-UID,这里需要先做一个小的转换,把大写字母全部改为小写,把所有的-改为下划线,就变成了x_uid,然后在前面拼接上$upstream_http_
,就得到了最终的结果$upstream_http_x_uid
新しいログ形式を作成します
log_format は http セグメントにのみ保存できるため、nginx.conf ファイルを見つける必要があります。
nginx のデフォルトのログ形式の 2 番目の部分はユーザー情報ですが、通常は何もなく、- だけがここでバックエンドから渡すヘッダー情報に変換されます。上で作成した特別なヘッダーは X-UID です。ここでは、最初に小さな変換を行う必要があります。すべての大文字を小文字に変更し、すべてをアンダースコアに変更すると、x_uid になり、次に < 先頭コード>$upstream_http_ を結合します。 code> を実行すると、最終結果 $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"';
in このログ形式はサーバーで参照されます
サーバー関連の設定では、上でログ形式にfrontという名前を付けたため、ここで参照する場合は、フロントログ形式を指定する必要があります:
access_log /var/log/nginx/front-access.log front;
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"
上記の 2 番目の数字は 52248 で、ログインしているユーザーの個人 ID です。ここでの例は比較的単純です。手間を気にしないのであれば、ログインしているユーザーの携帯電話番号や電子メール アドレスを含むすべての個人情報をログに出力することもできます。セキュリティの問題について。
ユーザーから ID を非表示にします
上記の最初のステップでは、PHP を使用して特別なヘッダーを出力しました。元々、ヘッダーは nginx で使用するためだけに使用されていましたが、このヘッダーは nginx によってそのまま残されます。フロントエンドに関しては、注意深いユーザーは動揺するかもしれません。このため、nginx サーバー設定に小さなスイッチを追加して、このヘッダーを非表示にすることができます:
proxy_hide_header X-UID;
概要
以上がnginxアクセスログを使用してmysqlにユーザーIDを記録するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











WebアプリケーションにおけるMySQLの主な役割は、データを保存および管理することです。 1.MYSQLは、ユーザー情報、製品カタログ、トランザクションレコード、その他のデータを効率的に処理します。 2。SQLクエリを介して、開発者はデータベースから情報を抽出して動的なコンテンツを生成できます。 3.MYSQLは、クライアントサーバーモデルに基づいて機能し、許容可能なクエリ速度を確保します。

Laravelは、Webアプリケーションを簡単に構築するためのPHPフレームワークです。次のような強力な機能を提供します。インストール:Laravel CLIを作曲家にグローバルにインストールし、プロジェクトディレクトリにアプリケーションを作成します。ルーティング:ルート/web.phpのURLとハンドラーの関係を定義します。ビュー:リソース/ビューでビューを作成して、アプリケーションのインターフェイスをレンダリングします。データベース統合:MySQLなどのデータベースとのすぐ外側の統合を提供し、移行を使用してテーブルを作成および変更します。モデルとコントローラー:モデルはデータベースエンティティを表し、コントローラーはHTTP要求を処理します。

DockerでMySQLを起動するプロセスは、次の手順で構成されています。MySQLイメージをプルしてコンテナを作成および起動し、ルートユーザーパスワードを設定し、ポート検証接続をマップしてデータベースを作成し、ユーザーはすべての権限をデータベースに付与します。

MySQLとPHPMyAdminは、強力なデータベース管理ツールです。 1)MySQLは、データベースとテーブルを作成し、DMLおよびSQLクエリを実行するために使用されます。 2)PHPMyAdminは、データベース管理、テーブル構造管理、データ操作、ユーザー許可管理のための直感的なインターフェイスを提供します。

小さなアプリケーションを開発する際には、軽量データベース操作ライブラリをすばやく統合する必要性という厄介な問題に遭遇しました。複数のライブラリを試した後、私はそれらがあまりにも多くの機能を持っているか、あまり互換性がないかのどちらかであることがわかりました。最終的に、私は問題を完全に解決したYii2に基づいた単純化されたバージョンであるMinii/DBを見つけました。

他のプログラミング言語と比較して、MySQLは主にデータの保存と管理に使用されますが、Python、Java、Cなどの他の言語は論理処理とアプリケーション開発に使用されます。 MySQLは、データ管理のニーズに適した高性能、スケーラビリティ、およびクロスプラットフォームサポートで知られていますが、他の言語は、データ分析、エンタープライズアプリケーション、システムプログラミングなどのそれぞれの分野で利点があります。

記事の概要:この記事では、Laravelフレームワークを簡単にインストールする方法について読者をガイドするための詳細なステップバイステップの指示を提供します。 Laravelは、Webアプリケーションの開発プロセスを高速化する強力なPHPフレームワークです。このチュートリアルは、システム要件からデータベースの構成とルーティングの設定までのインストールプロセスをカバーしています。これらの手順に従うことにより、読者はLaravelプロジェクトのための強固な基盤を迅速かつ効率的に築くことができます。

MySQLの基本操作には、データベース、テーブルの作成、およびSQLを使用してデータのCRUD操作を実行することが含まれます。 1.データベースの作成:createdatabasemy_first_db; 2。テーブルの作成:createTableBooks(idintauto_incrementprimarykey、titlevarchary(100)notnull、authorvarchar(100)notnull、published_yearint); 3.データの挿入:InsertIntoBooks(タイトル、著者、公開_year)VA
