Html.php 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | ThinkPHP [ WE CAN DO IT JUST THINK IT ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2006-2016 http://thinkphp.cn All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
  8. // +----------------------------------------------------------------------
  9. // | Author: liu21st <liu21st@gmail.com>
  10. // +----------------------------------------------------------------------
  11. declare (strict_types = 1);
  12. namespace think\trace;
  13. use think\App;
  14. use think\Response;
  15. /**
  16. * 页面Trace调试
  17. */
  18. class Html
  19. {
  20. protected $config = [
  21. 'file' => '',
  22. 'tabs' => ['base' => '基本', 'file' => '文件', 'info' => '流程', 'notice|error' => '错误', 'sql' => 'SQL', 'debug|log' => '调试'],
  23. ];
  24. // 实例化并传入参数
  25. public function __construct(array $config = [])
  26. {
  27. $this->config = array_merge($this->config, $config);
  28. }
  29. /**
  30. * 调试输出接口
  31. * @access public
  32. * @param App $app 应用实例
  33. * @param Response $response Response对象
  34. * @param array $log 日志信息
  35. * @return bool|string
  36. */
  37. public function output(App $app, Response $response, array $log = [])
  38. {
  39. $request = $app->request;
  40. $contentType = $response->getHeader('Content-Type');
  41. if ($request->isJson() || $request->isAjax()) {
  42. return false;
  43. } elseif (!empty($contentType) && strpos($contentType, 'html') === false) {
  44. return false;
  45. } elseif ($response->getCode() == 204) {
  46. return false;
  47. }
  48. // 获取基本信息
  49. $runtime = number_format(microtime(true) - $app->getBeginTime(), 10, '.', '');
  50. $reqs = $runtime > 0 ? number_format(1 / $runtime, 2) : '∞';
  51. $mem = number_format((memory_get_usage() - $app->getBeginMem()) / 1024, 2);
  52. // 页面Trace信息
  53. if ($request->host()) {
  54. $uri = $request->protocol() . ' ' . $request->method() . ' : ' . $request->url(true);
  55. } else {
  56. $uri = 'cmd:' . implode(' ', $_SERVER['argv']);
  57. }
  58. $base = [
  59. '请求信息' => date('Y-m-d H:i:s', $request->time() ?: time()) . ' ' . $uri,
  60. '运行时间' => number_format((float) $runtime, 6) . 's [ 吞吐率:' . $reqs . 'req/s ] 内存消耗:' . $mem . 'kb 文件加载:' . count(get_included_files()),
  61. '查询信息' => $app->db->getQueryTimes() . ' queries',
  62. '缓存信息' => $app->cache->getReadTimes() . ' reads,' . $app->cache->getWriteTimes() . ' writes',
  63. ];
  64. if (isset($app->session)) {
  65. $base['会话信息'] = 'SESSION_ID=' . $app->session->getId();
  66. }
  67. $info = $this->getFileInfo();
  68. // 页面Trace信息
  69. $trace = [];
  70. foreach ($this->config['tabs'] as $name => $title) {
  71. $name = strtolower($name);
  72. switch ($name) {
  73. case 'base': // 基本信息
  74. $trace[$title] = $base;
  75. break;
  76. case 'file': // 文件信息
  77. $trace[$title] = $info;
  78. break;
  79. default: // 调试信息
  80. if (strpos($name, '|')) {
  81. // 多组信息
  82. $names = explode('|', $name);
  83. $result = [];
  84. foreach ($names as $item) {
  85. $result = array_merge($result, $log[$item] ?? []);
  86. }
  87. $trace[$title] = $result;
  88. } else {
  89. $trace[$title] = $log[$name] ?? '';
  90. }
  91. }
  92. }
  93. // 调用Trace页面模板
  94. ob_start();
  95. include $this->config['file'] ?: __DIR__ . '/tpl/page_trace.tpl';
  96. return ob_get_clean();
  97. }
  98. /**
  99. * 获取文件加载信息
  100. * @access protected
  101. * @return integer|array
  102. */
  103. protected function getFileInfo()
  104. {
  105. $files = get_included_files();
  106. $info = [];
  107. foreach ($files as $key => $file) {
  108. $info[] = $file . ' ( ' . number_format(filesize($file) / 1024, 2) . ' KB )';
  109. }
  110. return $info;
  111. }
  112. }