-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDebug.php
92 lines (83 loc) · 2.04 KB
/
Debug.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
<?php
namespace resource;
class Debug
{
const IS_STOP = true;
public static $beginTime;
/**
* 开启计时
*/
public static function begin()
{
static::$beginTime = microtime(true);
}
/**
* 是否ajax请求
* @return bool
*/
private static function isAjax()
{
$isAjax = isset($_SERVER['HTTP_X_REQUESTED_WITH']) && $_SERVER['HTTP_X_REQUESTED_WITH'] === 'XMLHttpRequest' || isset($_GET['_isAjax']) || isset($_POST['_isAjax']);
return $isAjax ? true : false;
}
/**
* 调试基础版
* @param $data
*/
public static function basic($data)
{
var_dump($data);
echo PHP_EOL;
if (static::$beginTime) echo '耗时:'.(microtime(true) - static::$beginTime);
}
/**
* 调试进阶版
* @param $data
* @param $isStop
*/
public static function advance($data, $isStop = self::IS_STOP)
{
$trace = (new \Exception())->getTrace()[0];
echo '<br>文件号:'.$trace['file'].':'.$trace['line'];
self::basic($data);
self::stop($isStop);
}
/**
* 调试高级版
* @param $data
* @param $isStop
*/
public static function senior($data, $isStop = self::IS_STOP) {
if (self::isAjax()) {
self::ajax($data, $isStop);
}else{
self::advance($data, $isStop);
}
}
/**
* ajax调试
* @param $data
* @param $isStop
*/
public static function ajax($data, $isStop = self::IS_STOP)
{
$trace = (new \Exception())->getTrace()[0];
header('Content-type:application/json;charset=utf-8');
$json = json_encode([
'file' => $trace['file'],
'line' => $trace['line'],
'dataString' => var_export($data, true),
'data' => $data
]);
echo $json;
self::stop($isStop);
}
/**
* 断点
* @param $isStop
*/
private static function stop($isStop = self::IS_STOP)
{
$isStop && exit;
}
}