ShowPageTraceBehavior.class.php 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | ThinkPHP [ WE CAN DO IT JUST THINK IT ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2006-2014 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. namespace Behavior;
  12. /**
  13. * 系统行为扩展:页面Trace显示输出
  14. */
  15. class ShowPageTraceBehavior
  16. {
  17. protected $tracePageTabs = array('BASE' => '基本', 'FILE' => '文件', 'INFO' => '流程', 'ERR|NOTIC' => '错误', 'SQL' => 'SQL', 'DEBUG' => '调试');
  18. // 行为扩展的执行入口必须是run
  19. public function run(&$params)
  20. {
  21. if (!IS_AJAX && !IS_CLI && C('SHOW_PAGE_TRACE')) {
  22. echo $this->showTrace();
  23. }
  24. }
  25. /**
  26. * 显示页面Trace信息
  27. * @access private
  28. */
  29. private function showTrace()
  30. {
  31. // 系统默认显示信息
  32. $files = get_included_files();
  33. $info = array();
  34. foreach ($files as $key => $file) {
  35. $info[] = $file . ' ( ' . number_format(filesize($file) / 1024, 2) . ' KB )';
  36. }
  37. $trace = array();
  38. $base = array(
  39. '请求信息' => date('Y-m-d H:i:s', $_SERVER['REQUEST_TIME']) . ' ' . $_SERVER['SERVER_PROTOCOL'] . ' ' . $_SERVER['REQUEST_METHOD'] . ' : ' . __SELF__,
  40. '运行时间' => $this->showTime(),
  41. '吞吐率' => number_format(1 / G('beginTime', 'viewEndTime'), 2) . 'req/s',
  42. '内存开销' => MEMORY_LIMIT_ON ? number_format((memory_get_usage() - $GLOBALS['_startUseMems']) / 1024, 2) . ' kb' : '不支持',
  43. '查询信息' => N('db_query') . ' queries ' . N('db_write') . ' writes ',
  44. '文件加载' => count(get_included_files()),
  45. '缓存信息' => N('cache_read') . ' gets ' . N('cache_write') . ' writes ',
  46. '配置加载' => count(C()),
  47. '会话信息' => 'SESSION_ID=' . session_id(),
  48. );
  49. // 读取应用定义的Trace文件
  50. $traceFile = COMMON_PATH . 'Conf/trace.php';
  51. if (is_file($traceFile)) {
  52. $base = array_merge($base, include $traceFile);
  53. }
  54. $debug = trace();
  55. $tabs = C('TRACE_PAGE_TABS', null, $this->tracePageTabs);
  56. foreach ($tabs as $name => $title) {
  57. switch (strtoupper($name)) {
  58. case 'BASE': // 基本信息
  59. $trace[$title] = $base;
  60. break;
  61. case 'FILE': // 文件信息
  62. $trace[$title] = $info;
  63. break;
  64. default: // 调试信息
  65. $name = strtoupper($name);
  66. if (strpos($name, '|')) {
  67. // 多组信息
  68. $names = explode('|', $name);
  69. $result = array();
  70. foreach ($names as $name) {
  71. $result += isset($debug[$name]) ? $debug[$name] : array();
  72. }
  73. $trace[$title] = $result;
  74. } else {
  75. $trace[$title] = isset($debug[$name]) ? $debug[$name] : '';
  76. }
  77. }
  78. }
  79. if ($save = C('PAGE_TRACE_SAVE')) {
  80. // 保存页面Trace日志
  81. if (is_array($save)) { // 选择选项卡保存
  82. $tabs = C('TRACE_PAGE_TABS', null, $this->tracePageTabs);
  83. $array = array();
  84. foreach ($save as $tab) {
  85. $array[] = $tabs[$tab];
  86. }
  87. }
  88. $content = date('[ c ]') . ' ' . get_client_ip() . ' ' . $_SERVER['REQUEST_URI'] . "\r\n";
  89. foreach ($trace as $key => $val) {
  90. if (!isset($array) || in_array_case($key, $array)) {
  91. $content .= '[ ' . $key . " ]\r\n";
  92. if (is_array($val)) {
  93. foreach ($val as $k => $v) {
  94. $content .= (!is_numeric($k) ? $k . ':' : '') . print_r($v, true) . "\r\n";
  95. }
  96. } else {
  97. $content .= print_r($val, true) . "\r\n";
  98. }
  99. $content .= "\r\n";
  100. }
  101. }
  102. error_log(str_replace('<br/>', "\r\n", $content), 3, C('LOG_PATH') . date('y_m_d') . '_trace.log');
  103. }
  104. unset($files, $info, $base);
  105. // 调用Trace页面模板
  106. ob_start();
  107. include C('TMPL_TRACE_FILE') ? C('TMPL_TRACE_FILE') : THINK_PATH . 'Tpl/page_trace.tpl';
  108. return ob_get_clean();
  109. }
  110. /**
  111. * 获取运行时间
  112. */
  113. private function showTime()
  114. {
  115. // 显示运行时间
  116. G('beginTime', $GLOBALS['_beginTime']);
  117. G('viewEndTime');
  118. // 显示详细运行时间
  119. return G('beginTime', 'viewEndTime') . 's ( Load:' . G('beginTime', 'loadTime') . 's Init:' . G('loadTime', 'initTime') . 's Exec:' . G('initTime', 'viewStartTime') . 's Template:' . G('viewStartTime', 'viewEndTime') . 's )';
  120. }
  121. }