検索
ホームページデータベースmysql チュートリアル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

ここでは、1 つの情報を出力するだけでなく、名前、性別、年齢などを含む複数の異なるフィールドを出力することもできます。


新しいログ形式を作成します
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 には影響しません。それを記録します。 🎜🎜🎜🎜最終処理🎜🎜🎜🎜🎜それでは、IDの記録にそれほどの労力を費やして何の意味があるのでしょうか?これはとても役に立ちます。ログ分析用の強力なツールである logstash があることは誰もが知っています。これを ELK コンポーネントと組み合わせると、Apache または nginx ログの分析と処理に使用できます。このID情報がなければ、せいぜいユーザーがどのWebページに頻繁にアクセスしているのかを分析することしかできません。しかし、ユーザー ID を取得したので、分析のために mysql データベース テーブルに接続して、どの年齢層、性別、都市のユーザーがどの Web ページにアクセスするかを調査し、ターゲットを絞った方法で特定の Web ページを理解することもできます。 、どの Web ページにどの時間帯にアクセスしたいかを特定し、カスタマイズされたサービスを提供します。これでも十分強力ではないでしょうか? 🎜

概要

以上がnginxアクセスログを使用してmysqlにユーザーIDを記録するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
MySQLでビューを使用することの限界は何ですか?MySQLでビューを使用することの限界は何ですか?May 14, 2025 am 12:10 AM

mysqlviewshavelimitations:1)supportallsqloperations、制限、dataManipulationswithjoinsorubqueries.2)それらは、特にパフォーマンス、特にパルフェクソルラージャターセット

MySQLデータベースのセキュリティ:ユーザーの追加と特権の付与MySQLデータベースのセキュリティ:ユーザーの追加と特権の付与May 14, 2025 am 12:09 AM

reperusermanmanagementInmysqliscialforenhancingsecurationsinginuring databaseaperation.1)usecreateusertoaddusers、指定connectionsourcewith@'localhost'or@'% '。

MySQLで使用できるトリガーの数にどのような要因がありますか?MySQLで使用できるトリガーの数にどのような要因がありますか?May 14, 2025 am 12:08 AM

mysqldoes notimposeahardlimitontriggers、しかしpracticalfactorsdeTerminetheireffectiveuse:1)serverconufigurationStriggermanagement; 2)complentiggersincreaseSystemload;

mysql:Blobを保管しても安全ですか?mysql:Blobを保管しても安全ですか?May 14, 2025 am 12:07 AM

はい、それはssafetostoreblobdatainmysql、butonsiderheSeCactors:1)Storagespace:blobscanconsumesificantspace.2)パフォーマンス:パフォーマンス:大規模なドゥエットブロブスメイズ階下3)backupandrecized recized recized recize

MySQL:PHP Webインターフェイスを介してユーザーを追加しますMySQL:PHP Webインターフェイスを介してユーザーを追加しますMay 14, 2025 am 12:04 AM

PHP Webインターフェイスを介してMySQLユーザーを追加すると、MySQLI拡張機能を使用できます。手順は次のとおりです。1。MySQLデータベースに接続し、MySQLI拡張機能を使用します。 2。ユーザーを作成し、CreateUserステートメントを使用し、パスワード()関数を使用してパスワードを暗号化します。 3. SQLインジェクションを防ぎ、MySQLI_REAL_ESCAPE_STRING()関数を使用してユーザー入力を処理します。 4.新しいユーザーに権限を割り当て、助成金ステートメントを使用します。

MySQL:BLOBおよびその他のNO-SQLストレージ、違いは何ですか?MySQL:BLOBおよびその他のNO-SQLストレージ、違いは何ですか?May 13, 2025 am 12:14 AM

mysql'sblobissuitable forstoringbinarydatawithinarationaldatabase、whileenosqloptionslikemongodb、redis、andcassandraofferferulesions forunstructureddata.blobissimplerbutcanslowdowdowd withwithdata

MySQLユーザーの追加:構文、オプション、セキュリティのベストプラクティスMySQLユーザーの追加:構文、オプション、セキュリティのベストプラクティスMay 13, 2025 am 12:12 AM

toaddauserinmysql、使用:createuser'username '@' host'identifidedby'password '; here'showtodoitsely:1)chosehostcarefilytoconを選択しますTrolaccess.2)setResourcelimitslikemax_queries_per_hour.3)usestrong、uniquasswords.4)endforcessl/tlsconnectionswith

MySQL:文字列データ型の一般的な間違いを回避する方法MySQL:文字列データ型の一般的な間違いを回避する方法May 13, 2025 am 12:09 AM

toavoidcommonMonmistakeswithStringDatatypesinmysql、undultingStringTypenuste、choosetherightType、andManageEncodingandCollat​​ionsEttingtingive.1)U​​secharforfixed-LengthStrings、Varcharforaible Length、AndText/Blobforlardata.2)setCurrectCherts

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境

SublimeText3 中国語版

SublimeText3 中国語版

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