


Beispielanalyse: Wie thinkphp Middleware verwendet, um Verhaltensprotokolle aufzuzeichnen
Dieser Artikel vermittelt Ihnen relevantes Wissen über PHP. Er befasst sich hauptsächlich mit dem Problem der Verwendung von Middleware zum Aufzeichnen von Verhaltensprotokollen, einschließlich der Verwendung von Protokollkanälen zum vorübergehenden Speichern von Verhaltensprotokollen und der Verwendung geplanter Aufgaben zum zeitlichen Schreiben von Protokollinhalten Datenbank usw. Werfen wir einen Blick darauf. Ich hoffe, es wird für alle hilfreich sein.
Empfohlenes Lernen: „PHP-Video-Tutorial“
1. Definieren Sie Middleware
Sie können Middleware schnell über Befehlszeilenanweisungen generieren
php think make:middleware Behavior
Dieser Befehl generiert ein Verhalten im Verzeichnis „app/middleware“. Middleware. Der Inhalt lautet wie folgt:
<?phpdeclare (strict_types = 1);namespace app\middleware;use think\facade\Log;class Behavior{ /** * 处理请求 * * @param \think\Request $request * @param \Closure $next * @return Response */ public function handle($request, \Closure $next) { //start 加入以下内容 $admin = get_admin_info(); //当前登录用户的信息,自己实现 $method = strtolower($request->method()); $is_ajax = $request->isAjax(); $route = $request->pathinfo(); $req = $_REQUEST; unset($req['s'],$req['_session']); $req_data = $req ? json_encode($req) : ''; $data = [ 'admin_id' => $admin['id'], //操作人id 'admin_user' => $admin['user'], //操作人用户名 'route' => $route, //操作的路由地址 'method' => $method, //get/post 'req_tp' => $is_ajax ? 'ajax' : 'normal', 'req_data' => $req_data, //get/post的数据 'ip' => getIp(), 'create_time' => time() ]; //end return $next($request); }}
2. Verwenden Sie den Protokollkanal, um Verhaltensprotokolle vorübergehend zu speichern.
Es wird nicht empfohlen, Verhaltensprotokolle in Echtzeit in die Datenbank zu schreiben, da dies die Datenbank unnötig belastet Protokolldatei-Cache und regelmäßig in der Datenbank speichern 提示:先阅读官方日志处理教程 https://www.kancloud.cn/manual/thinkphp6_0/1037616
Protokollverarbeitung
1. Ändern Sie die Protokollkonfigurationsdatei
Öffnen Sie config/log.php in „Kanäle“ => [] und fügen Sie schließlich einen separaten Kanal für die Aufzeichnung hinzu Verhaltensprotokolle:
// 其它日志通道配置 //行为日志 'behavior' => [ 'path' => runtime_path().'behavior', //日志存放目录 'type' => 'File', 'single' => 'b', //单一文件日志:文件名 'file_size' => 1024*1024*10, //日志文件大小限制(超出会生成多个文件 'max_files' => 30, //文件最大数量 'realtime_write' => false, // 关闭实时写入 ],
2. Registrieren Sie die globale Middleware
Öffnen Sie app/middleware.php und registrieren Sie ein Verhaltensprotokoll für die globale Middleware
<?php // 全局中间件定义文件return [ // 全局请求缓存 // \think\middleware\CheckRequestCache::class, // 多语言加载 // \think\middleware\LoadLangPack::class, // Session初始化 // \think\middleware\SessionInit::class // 行为日志 \app\middleware\Behavior::class, ];
3. Testen Sie, ob das Protokoll erfolgreich generiert werden kann
Besuchen Sie eine beliebige Seite dieses Projekts , zum Beispiel: http://www.tp6.com/index/ index/test?a=1&b=2, prüfen Sie, ob die folgende Datei generiert werden kann
Öffnen Sie die Datei, die Daten wurden geschrieben
{"time":"2022-04-16T21:38:48+08:00" ,"type":info,msg:{"admin_id":888,"admin_user:fanchen", Route:: „Index/Index/Test“, „Methode“: „Get“, „req_tp“: „normal“, „req_data“: „{“a“: „1“, „b“: „2“}“ ,"ip":"127.0.0.1","create_time":1650116328}"}
3. Verwenden Sie geplante Aufgaben, um regelmäßig Protokollinhalte in die Datenbank zu schreiben
1. Erstellen Sie eine neue API-Methode, die die geplanten Aufgaben erfordert um zugänglich zu sein
/** * 定时任务服务器定时将用户行为日志插入到数据库 * @return void */ public function sync_behavior_log() { $path = runtime_path() . 'behavior/b.log'; $b_file = file_get_contents($path); $b_arr = explode(PHP_EOL, $b_file); $d = []; foreach ($b_arr as $b) { $data = json_decode($b, true); if (!empty($data['msg'])) { $d[] = json_decode($data['msg'], true); } } if ($d) { try { Db::name('log_behavior')->insertAll($d); //批量插入数据库 file_put_contents($path, ''); //清空文件日志 echo '采集用户行为日志成功' . count($d); } catch (DbException $e) { echo ($e->getMessage()); } } }
2. Erstellen Sie eine neue Verhaltensprotokolldatentabelle log_behavior
SET NAMES utf8mb4; SET FOREIGN_KEY_CHECKS = 0; -- ---------------------------- -- Table structure for log_behavior -- ---------------------------- DROP TABLE IF EXISTS `log_behavior`; CREATE TABLE `log_behavior` ( `id` int(10) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT 'ID', `admin_id` int(11) NOT NULL DEFAULT 0 COMMENT '用户id', `admin_user` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '用户名', `route` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '模块名称', `method` enum('delete','put','post','get') CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT 'get' COMMENT '请求方式 1get 2post 3put 4delete', `req_data` varchar(300) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '请求数据', `ip` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '用户ip', `create_time` int(11) NOT NULL DEFAULT 0 COMMENT '创建时间', PRIMARY KEY (`id`) USING BTREE, INDEX `uid`(`admin_id`) USING BTREE, INDEX `admin_user`(`admin_user`) USING BTREE, INDEX `route`(`route`) USING BTREE ) ENGINE = InnoDB AUTO_INCREMENT = 3902195 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '行为日志' ROW_FORMAT = Compact; SET FOREIGN_KEY_CHECKS = 1;
3. Erstellen Sie eine neue geplante Aufgabe und greifen Sie regelmäßig auf die sync_behavior_log-Adresse in Schritt 1 zu. Es wird empfohlen, dies einmal zu tun alle 5 Minuten
Wenn ein Benutzer zu diesem Zeitpunkt auf die Datentabelle zugreift, werden die Verhaltensprotokolldaten in regelmäßigen Abständen stapelweise eingefügt
Empfohlenes Lernen: „
PHP-Video-TutorialDas obige ist der detaillierte Inhalt vonBeispielanalyse: Wie thinkphp Middleware verwendet, um Verhaltensprotokolle aufzuzeichnen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

MantisBT
Mantis ist ein einfach zu implementierendes webbasiertes Tool zur Fehlerverfolgung, das die Fehlerverfolgung von Produkten unterstützen soll. Es erfordert PHP, MySQL und einen Webserver. Schauen Sie sich unsere Demo- und Hosting-Services an.

EditPlus chinesische Crack-Version
Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion

SublimeText3 Englische Version
Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

SublimeText3 Linux neue Version
SublimeText3 Linux neueste Version

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor
