mirror of
https://gitee.com/fastadminnet/framework.git
synced 2026-07-01 12:42:48 +08:00
改进异常页面显示
This commit is contained in:
@@ -99,8 +99,6 @@ return [
|
||||
// 默认跳转页面对应的模板文件
|
||||
'dispatch_success_tmpl' => THINK_PATH . 'tpl' . DS . 'dispatch_jump.tpl',
|
||||
'dispatch_error_tmpl' => THINK_PATH . 'tpl' . DS . 'dispatch_jump.tpl',
|
||||
// 默认的模板引擎
|
||||
'template_engine' => 'Think',
|
||||
|
||||
// +----------------------------------------------------------------------
|
||||
// | 异常及错误设置
|
||||
|
||||
@@ -33,14 +33,6 @@ class Error
|
||||
*/
|
||||
public static function appException($exception)
|
||||
{
|
||||
/* 非API模式下的部署模式,跳转到指定的 Error Page */
|
||||
if (!(APP_DEBUG || IS_API)) {
|
||||
$error_page = Config::get('error_page');
|
||||
if (!empty($error_page)) {
|
||||
header("Location: {$error_page}");
|
||||
}
|
||||
}
|
||||
|
||||
// 收集异常数据
|
||||
if (APP_DEBUG) {
|
||||
// 调试模式,获取详细的错误信息
|
||||
@@ -77,6 +69,15 @@ class Error
|
||||
|
||||
// 记录异常日志
|
||||
Log::record($log, 'error');
|
||||
|
||||
/* 非API模式下的部署模式,跳转到指定的 Error Page */
|
||||
if (!(APP_DEBUG || IS_API)) {
|
||||
$error_page = Config::get('error_page');
|
||||
if (!empty($error_page)) {
|
||||
header("Location: {$error_page}");
|
||||
}
|
||||
}
|
||||
|
||||
// 输出错误信息
|
||||
self::output($exception, $data);
|
||||
// 禁止往下传播已处理过的异常
|
||||
@@ -144,9 +145,9 @@ class Error
|
||||
http_response_code($exception instanceof Exception ? $exception->getHttpStatus() : 500);
|
||||
|
||||
$type = Config::get('default_return_type');
|
||||
if (!APP_DEBUG) {
|
||||
// 部署模式不显示详细错误信息
|
||||
$data['message'] = Config::get('show_error_msg');
|
||||
if (!APP_DEBUG && !Config::get('show_error_msg')) {
|
||||
// 不显示详细错误信息
|
||||
$data['message'] = Config::get('error_message');
|
||||
}
|
||||
if (IS_API && 'html' != $type) {
|
||||
// 异常信息输出监听
|
||||
@@ -220,53 +221,10 @@ class Error
|
||||
*/
|
||||
private static function getTPConst()
|
||||
{
|
||||
return [
|
||||
'THINK_VERSION' => defined('THINK_VERSION') ? THINK_VERSION : 'undefined',
|
||||
'THINK_PATH' => defined('THINK_PATH') ? THINK_PATH : 'undefined',
|
||||
'LIB_PATH' => defined('LIB_PATH') ? LIB_PATH : 'undefined',
|
||||
'EXTEND_PATH' => defined('EXTEND_PATH') ? EXTEND_PATH : 'undefined',
|
||||
'MODE_PATH' => defined('MODE_PATH') ? MODE_PATH : 'undefined',
|
||||
'CORE_PATH' => defined('CORE_PATH') ? CORE_PATH : 'undefined',
|
||||
'TRAIT_PATH' => defined('TRAIT_PATH') ? TRAIT_PATH : 'undefined',
|
||||
'APP_PATH' => defined('APP_PATH') ? APP_PATH : 'undefined',
|
||||
'RUNTIME_PATH' => defined('RUNTIME_PATH') ? RUNTIME_PATH : 'undefined',
|
||||
'LOG_PATH' => defined('LOG_PATH') ? LOG_PATH : 'undefined',
|
||||
'CACHE_PATH' => defined('CACHE_PATH') ? CACHE_PATH : 'undefined',
|
||||
'TEMP_PATH' => defined('TEMP_PATH') ? TEMP_PATH : 'undefined',
|
||||
'VENDOR_PATH' => defined('VENDOR_PATH') ? VENDOR_PATH : 'undefined',
|
||||
'MODULE_PATH' => defined('MODULE_PATH') ? MODULE_PATH : 'undefined',
|
||||
'VIEW_PATH' => defined('VIEW_PATH') ? VIEW_PATH : 'undefined',
|
||||
'APP_NAMESPACE' => defined('APP_NAMESPACE') ? APP_NAMESPACE : 'undefined',
|
||||
'COMMON_MODULE' => defined('COMMON_MODULE') ? COMMON_MODULE : 'undefined',
|
||||
'APP_MULTI_MODULE' => defined('APP_MULTI_MODULE') ? APP_MULTI_MODULE : 'undefined',
|
||||
'MODULE_ALIAS' => defined('MODULE_ALIAS') ? MODULE_ALIAS : 'undefined',
|
||||
'MODULE_NAME' => defined('MODULE_NAME') ? MODULE_NAME : 'undefined',
|
||||
'CONTROLLER_NAME' => defined('CONTROLLER_NAME') ? CONTROLLER_NAME : 'undefined',
|
||||
'ACTION_NAME' => defined('ACTION_NAME') ? ACTION_NAME : 'undefined',
|
||||
'MODEL_LAYER' => defined('MODEL_LAYER') ? MODEL_LAYER : 'undefined',
|
||||
'VIEW_LAYER' => defined('VIEW_LAYER') ? VIEW_LAYER : 'undefined',
|
||||
'CONTROLLER_LAYER' => defined('CONTROLLER_LAYER') ? CONTROLLER_LAYER : 'undefined',
|
||||
'APP_DEBUG' => defined('APP_DEBUG') ? APP_DEBUG : 'undefined',
|
||||
'APP_HOOK' => defined('APP_HOOK') ? APP_HOOK : 'undefined',
|
||||
'ENV_PREFIX' => defined('ENV_PREFIX') ? ENV_PREFIX : 'undefined',
|
||||
'IS_API' => defined('IS_API') ? IS_API : 'undefined',
|
||||
'APP_AUTO_RUN' => defined('APP_AUTO_RUN') ? APP_AUTO_RUN : 'undefined',
|
||||
'APP_MODE' => defined('APP_MODE') ? APP_MODE : 'undefined',
|
||||
'REQUEST_METHOD' => defined('REQUEST_METHOD') ? REQUEST_METHOD : 'undefined',
|
||||
'IS_CGI' => defined('IS_CGI') ? IS_CGI : 'undefined',
|
||||
'IS_WIN' => defined('IS_WIN') ? IS_WIN : 'undefined',
|
||||
'IS_CLI' => defined('IS_CLI') ? IS_CLI : 'undefined',
|
||||
'IS_AJAX' => defined('IS_AJAX') ? IS_AJAX : 'undefined',
|
||||
'IS_GET' => defined('IS_GET') ? IS_GET : 'undefined',
|
||||
'IS_POST' => defined('IS_POST') ? IS_POST : 'undefined',
|
||||
'IS_PUT' => defined('IS_PUT') ? IS_PUT : 'undefined',
|
||||
'IS_DELETE' => defined('IS_DELETE') ? IS_DELETE : 'undefined',
|
||||
'NOW_TIME' => defined('NOW_TIME') ? NOW_TIME : 'undefined',
|
||||
'LANG_SET' => defined('LANG_SET') ? LANG_SET : 'undefined',
|
||||
'EXT' => defined('EXT') ? EXT : 'undefined',
|
||||
'DS' => defined('DS') ? DS : 'undefined',
|
||||
'__INFO__' => defined('__INFO__') ? __INFO__ : 'undefined',
|
||||
'__EXT__' => defined('__EXT__') ? __EXT__ : 'undefined',
|
||||
];
|
||||
$consts = ['THINK_VERSION', 'THINK_PATH', 'LIB_PATH', 'EXTEND_PATH', 'MODE_PATH', 'CORE_PATH', 'TRAIT_PATH', 'APP_PATH', 'RUNTIME_PATH', 'LOG_PATH', 'CACHE_PATH', 'TEMP_PATH', 'MODULE_PATH', 'VIEW_PATH', 'APP_NAMESPACE', 'COMMON_MODULE', 'APP_MULTI_MODULE', 'MODULE_ALIAS', 'MODULE_NAME', 'CONTROLLER_NAME', 'ACTION_NAME', 'MODEL_LAYER', 'VIEW_LAYER', 'CONTROLLER_LAYER', 'APP_DEBUG', 'APP_HOOK', 'ENV_PREFIX', 'IS_API', 'VENDOR_PATH', 'APP_AUTO_RUN', 'APP_MODE', 'REQUEST_METHOD', 'IS_CGI', 'IS_WIN', 'IS_API', 'IS_CLI', 'IS_GET', 'IS_POST', 'IS_PUT', 'IS_AJAX', 'IS_DELETE', 'NOW_TIME', 'LANG_SET', 'EXT', 'DS', '__INFO__', '__EXT__'];
|
||||
foreach ($consts as $const) {
|
||||
$data[$const] = defined($const) ? constant($const) : 'undefined';
|
||||
}
|
||||
return $data;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -8,13 +8,13 @@
|
||||
/* Base */
|
||||
body{
|
||||
color: #333;
|
||||
font: 14px Verdana, "Helvetica Neue", helvetica, Arial, 'Microsoft YaHei', sans-serif;
|
||||
font: 16px Verdana, "Helvetica Neue", helvetica, Arial, 'Microsoft YaHei', sans-serif;
|
||||
margin: 0px;
|
||||
padding: 20px;
|
||||
}
|
||||
h1{
|
||||
margin: 0;
|
||||
font-size: 24px;
|
||||
font-size: 28px;
|
||||
font-weight: 500;
|
||||
line-height: 32px;
|
||||
}
|
||||
@@ -48,6 +48,20 @@
|
||||
}
|
||||
|
||||
/* Exception Info */
|
||||
.exception .message{
|
||||
padding: 12px;
|
||||
border: 1px solid #ddd;
|
||||
border-bottom: 0 none;
|
||||
line-height: 18px;
|
||||
font-size:16px;
|
||||
border-top-left-radius: 4px;
|
||||
border-top-right-radius: 4px;
|
||||
font-family: Consolas,"Liberation Mono",Courier,Verdana,"微软雅黑";
|
||||
}
|
||||
.exception .message div{
|
||||
margin:8px 0px;
|
||||
}
|
||||
|
||||
.exception .code{
|
||||
float: left;
|
||||
text-align: center;
|
||||
@@ -58,17 +72,15 @@
|
||||
background: #999;
|
||||
}
|
||||
.exception .source-code{
|
||||
margin-top: 12px;
|
||||
padding: 6px;
|
||||
border: 1px solid #ddd;
|
||||
border-top-left-radius: 4px;
|
||||
border-top-right-radius: 4px;
|
||||
|
||||
background: #f9f9f9;
|
||||
overflow-x: auto;
|
||||
|
||||
}
|
||||
.exception .source-code pre{
|
||||
margin: 0;
|
||||
font-family: Consolas,"Liberation Mono",Courier,"微软雅黑";
|
||||
}
|
||||
.exception .source-code pre ol{
|
||||
margin: 0;
|
||||
@@ -76,6 +88,8 @@
|
||||
display: inline-block;
|
||||
min-width: 100%;
|
||||
box-sizing: border-box;
|
||||
font-size:14px;
|
||||
font-family: "Century Gothic",Consolas,"Liberation Mono",Courier,Verdana;
|
||||
padding-left: <?php echo isset($source) ? parse_padding($source) : 40; ?>px;
|
||||
}
|
||||
.exception .source-code pre li{
|
||||
@@ -86,15 +100,18 @@
|
||||
.exception .source-code pre code{
|
||||
color: #333;
|
||||
height: 100%;
|
||||
padding-left: 6px;
|
||||
display: inline-block;
|
||||
border-left: 1px solid #fff;
|
||||
font-size:14px;
|
||||
font-family: Consolas,"Liberation Mono",Courier,Verdana,"微软雅黑";
|
||||
}
|
||||
.exception .trace{
|
||||
padding: 6px;
|
||||
border: 1px solid #ddd;
|
||||
border-top: 0 none;
|
||||
line-height: 16px;
|
||||
font-size:14px;
|
||||
font-family: Consolas,"Liberation Mono",Courier,Verdana,"微软雅黑";
|
||||
}
|
||||
.exception .trace ol{
|
||||
margin: 12px;
|
||||
@@ -168,15 +185,16 @@
|
||||
<body>
|
||||
<?php if(APP_DEBUG) { ?>
|
||||
<div class="exception">
|
||||
<h1>
|
||||
<span class="code"><?php echo $code; ?></span>
|
||||
<div class="message">
|
||||
|
||||
<div class="info">
|
||||
<div>
|
||||
<?php echo sprintf('%s in %s', parse_class($name), parse_file($file, $line)); ?>
|
||||
[<?php echo $code; ?>] <?php echo sprintf('%s in %s', parse_class($name), parse_file($file, $line)); ?>
|
||||
</div>
|
||||
<div><?php echo htmlentities($message); ?></div>
|
||||
<div><h1><?php echo htmlentities($message); ?></h1></div>
|
||||
</div>
|
||||
</h1>
|
||||
|
||||
</div>
|
||||
<div class="source-code">
|
||||
<pre class="prettyprint lang-php"><ol start="<?php echo $source['first']; ?>"><?php foreach ((array) $source['source'] as $key => $value) { ?><li class="line-<?php echo $key + $source['first']; ?>"><code><?php echo htmlentities($value); ?></code></li><?php } ?></ol></pre>
|
||||
</div>
|
||||
@@ -210,9 +228,9 @@
|
||||
</div>
|
||||
<?php } else { ?>
|
||||
<div class="exception">
|
||||
<h1>
|
||||
<div class="info"><?php echo htmlentities($message); ?></div>
|
||||
</h1>
|
||||
|
||||
<div class="info"><h1><?php echo htmlentities($message); ?></h1></div>
|
||||
|
||||
</div>
|
||||
<?php } ?>
|
||||
|
||||
|
||||
Reference in New Issue
Block a user