在tp5版本的时候日志中保存了全部的请求信息,保存了请求地址 请求方法 请求路由 请求头 请求参数,但是在tp6中官方取消了。官方解释说由于日志记录了所有的运行错误,因此养成经常查看日志文件的习惯,可以避免和及早发现很多的错误隐患。但是我觉得不方便我定位线上问题,于是把tp5源码中的部分移植到tp6中,tp5中大部分放在tp底层,为了不破坏tp框架我把代码放到中间件中进行继承,所有中间件全部继承此代码。自动记录请求信息。
<?php declare (strict_types=1); namespace app\middleware; use think\facade\Log; use think\Request; class Base { /** * 保存请求信息 * Base constructor. */ public function __construct() { $request = app(Request::class); $requestInfo = [ 'ip' => $request->ip(), 'method' => $request->method(), 'host' => $request->host(), 'uri' => $request->url(), ]; $logInfo = [ "{$requestInfo['ip']} {$requestInfo['method']} {$requestInfo['host']}{$requestInfo['uri']}", '[ ROUTE ] ' . var_export($this->getRouteInfo(), true), '[ HEADER ] ' . var_export($request->header(), true), '[ PARAM ] ' . var_export($request->param(), true), '---------------------------------------------------------------', ]; $logInfo = implode(PHP_EOL, $logInfo) . PHP_EOL; Log::record($logInfo, 'info'); } /** * 获取路由信息 * @return array */ protected function getRouteInfo(): array { $request = app(Request::class); return [ 'rule' => $request->rule()->getRule(), 'route' => $request->rule()->getRoute(), 'option' => $request->rule()->getOption(), 'var' => $request->rule()->getVars(), ]; } }
以上代码从Tp5查看源码实现的。所有中间件都继承base即可。生成的日志和tp5完全一样
[2021-07-07T21:09:50+08:00][info] 127.0.0.1 POST learn.cn/api/v3/up_professions
[ ROUTE ] array (
'rule' => 'v3/up_professions',
'route' => 'api/User/update',
'option' =>
array (
'remove_slash' => false,
'merge_rule_regex' => false,
'middleware' =>
array (
0 => 'app\\middleware\\CheckLogin',
),
),
'var' =>
array (
),
)
[ HEADER ] array (
'accept-encoding' => 'gzip, deflate',
'accept' => '*/*',
'token' => 'fjsfnsjdfneofnjsnsfgjnsga',
'content-type' => 'application/json',
'content-length' => '2',
'connection' => 'keep-alive',
'host' => 'learn.cn',
)
[ PARAM ] array (
)
---------------------------------------------------------------
<!doctype html> <html> <head> <meta charset="utf-8"> <title>demo</title> </head> <bod...
通过经纬度转换为城市名称,并获得城市的编号,通常在全国类型的商城中比较通用。//经纬度转城市名称(返回城市id,城市名称) //$ak开发密钥,$lat纬度,$lng经度,$type返回数据类型 public function getCityName($ak,$lat,$lng)...
开启错误提示代码:ini_set("display_errors", "On"); error_reporting(E_ALL | E_STRICT);关闭错误提示代码:error_reporting(E_ALL ^&n...
使用php函数array_multisort()即可实现和SQL一样的order by排序. 例如我们需要对会员表按照主键降序排列,年龄升序排列://会员表数据 $list = []; $list[] = ['mid' =>&n...
(1).在PHP中可以查看的环境变量包括: (1.1).电脑环境变量 (2.1).服务器环境变量(2).getenv()函数获取一个环境变量的值.参数1是环境变量的key,参数2值为true的时候仅从你的电脑环境变量中查找,参数2值为false会从两种变量中全部查询//获取我电脑登录的用户名,输出A...
<?php /** * daemonize让当前脚本为守护进程执行 * @param string $callback 匿名函数 */ function daemonize($callback) {...