Trace.php 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. <?php
  2. namespace application\index\behavior;
  3. class Trace
  4. {
  5. function actionBegin(){
  6. if(!config('enable_log_request') || IS_CLI) return;
  7. try {
  8. //error_reporting(E_ERROR | E_PARSE);
  9. //error_reporting(E_ALL);
  10. defined('IS_POST') or define('IS_POST', request()->isPost());
  11. defined('IS_AJAX') or define('IS_AJAX',request()->isAjax());
  12. defined('IS_GET') or define('IS_GET', request()->isGet());
  13. //不需要记录的url地址
  14. $blacklist = [
  15. "/index/news/getList",
  16. ];
  17. foreach ($blacklist as $v) {
  18. if (strpos($_SERVER['REQUEST_URI'], $v) !== false) return;
  19. }
  20. $data = array();
  21. $data['url'] = $_SERVER['REQUEST_SCHEME'] . '://' . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI'];
  22. if (IS_POST) {
  23. $params = $_POST;
  24. } elseif (IS_GET) {
  25. $params = $_GET;
  26. }
  27. if (empty($params)) $params['input'] = file_get_contents("php://input");
  28. $data['params'] = json_encode($params);
  29. //$data['cookie'] = json_encode($_COOKIE);
  30. //$data['user_agent'] = $_SERVER['HTTP_USER_AGENT'];
  31. $data['ip'] = get_client_ip();
  32. $detail = array();
  33. $detail['request'] = $_REQUEST;
  34. $header = [];
  35. $fields = ['HTTP_USER_ID', 'HTTP_DEVICE_VID', 'HTTP_DEVICE_ID', 'HTTP_PLATFORM', 'HTTP_VERSION']; //'HTTP_USER_AGENT',
  36. foreach ($fields as $k => $v) {
  37. if (empty($_SERVER[$v])) continue;
  38. $header[$v] = $_SERVER[$v];
  39. }
  40. /*$this->version = I('server.HTTP_VERSION');
  41. $this->device_id = I('device_id') ?:I('server.HTTP_DEVICE_ID');
  42. $this->platform = I('server.HTTP_PLATFORM');
  43. $user_id = I('user_id') ?: I('server.HTTP_USER_ID');
  44. $detail['server'] = $_SERVER;*/
  45. //$detail['header'] = $header;
  46. //$data['detail'] = json_encode($detail);
  47. $url = $_SERVER['REQUEST_METHOD'] . " " . $_SERVER['REQUEST_SCHEME'] . '://' . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI'] . " " . $_SERVER['SERVER_PROTOCOL'] . "\r\n";
  48. $request = $url . getallheaders(true);
  49. $raw_post = '';
  50. if (IS_POST) {
  51. $raw_post = http_build_query($_POST);
  52. if (empty($raw_post)) {
  53. $raw_post = file_get_contents("php://input");
  54. }
  55. }
  56. $request .= "\r\n" . $raw_post;
  57. $data['detail'] = $request;
  58. $data['user_agent'] = empty($_SERVER['HTTP_USER_AGENT']) ? '' : $_SERVER['HTTP_USER_AGENT'];
  59. //$data['platform'] = I('server.HTTP_PLATFORM');
  60. $data['user_id'] = I('user_id');////cookie可能取出null,要求字段必须可为null
  61. if (empty($data['user_id'])) {
  62. $userInfo = cookie('LOGIN_USER');
  63. $user_id = $userInfo['user_id'];
  64. $data['user_id'] = $user_id;
  65. }
  66. $data['create_time'] = date("Y-m-d H:i:s");
  67. $data['method'] = $_SERVER['REQUEST_METHOD'];
  68. //$data['date_int'] = time();
  69. $m = db('LogRequest');
  70. //$m->create($data);
  71. $result = $m->insert($data);
  72. $logId = $m->getLastInsID();
  73. config('logId', $logId);
  74. }catch (\Exception $e){
  75. tplog($e->getMessage());
  76. }
  77. \think\Db::listen(function($sql, $time, $explain){
  78. $logId = config('logId');
  79. if(!empty($logId) && strpos($sql,'log_request') === false){
  80. file_put_contents(RUNTIME_PATH."/$logId.sql", $sql.PHP_EOL, FILE_APPEND);
  81. }
  82. // 记录SQL
  83. //echo $sql. ' ['.$time.'s]';
  84. // 查看性能分析结果
  85. //dump($explain);
  86. });
  87. // exit('x');
  88. }
  89. }