behavior\Log.php 在tag.php里配置
'app_init' => [
'app\\index\\behavior\\Log',
],
<?php
namespace app\index\behavior;
use think\Request;
// 初始化钩子信息
class Log
{
// 行为扩展的执行入口必须是run
public function run(Request $request = null)
{
// 获取信息
$m['module'] = $_SERVER['DOCUMENT_URI'];
$m['c_id'] = $request->param('c_id', 0);
$m['func_name'] = $request->param('func_name', '');
$m['IP'] = $_SERVER["REMOTE_ADDR"];
$m['agent'] = $_SERVER['HTTP_USER_AGENT'];
$m['body'] = serialize(input('param.'));
$m['time'] = date('Y-m-d H:i:s', time());
// 加入 redis 队列
$redis = new \Redis();
$redis -> connect('127.0.0.1', 6379);
// 完毕
$redis -> rPush('api_shell_log', serialize($m));
}
}
log_daemon.php 守护进程
<?php
// +----------------------------------------------------------------------
// | Author: Liu Xiaoyu <[email protected]>
// +----------------------------------------------------------------------
// | Date: 2019/10/11 11:13
// +----------------------------------------------------------------------
$redis = new \Redis();
$redis -> connect('127.0.0.1', 6379);
while (true) {
try {
$value = $redis -> lPop('api_shell_log');
if (!$value) {
sleep(5);
continue;
}
$m = unserialize($value);
$content = <<<EOL
module: {$m['module']} c_id: {$m['c_id']} time: {$m['time']}
func_name: {$m['func_name']}
IP: {$m['IP']}
agent: {$m['agent']}
body: {$m['body']}
===================================================
EOL;
file_put_contents('log-'.date('Y-m-d',time()).'.txt', $content,FILE_APPEND);
// var_dump($value);
} catch (Exception $e) {
echo $e -> getMessage();
}
}
记得要给权限, 然后 php log_daemen.php & 放到后台执行即可