160 lines
2.9 KiB
PHP
160 lines
2.9 KiB
PHP
<?php
|
|
/**
|
|
* Created by PhpStorm.
|
|
* User: whwyy
|
|
* Date: 2018/4/26 0026
|
|
* Time: 10:00
|
|
*/
|
|
|
|
namespace Snowflake\Error;
|
|
|
|
use Exception;
|
|
use HttpServer\IInterface\IFormatter;
|
|
use Snowflake\Abstracts\Component;
|
|
use Snowflake\Core\JSON;
|
|
use Snowflake\Event;
|
|
use Snowflake\Snowflake;
|
|
|
|
/**
|
|
* Class ErrorHandler
|
|
*
|
|
* @package BeReborn\Base
|
|
* @property-read $asError
|
|
*/
|
|
class ErrorHandler extends Component implements ErrorInterface
|
|
{
|
|
|
|
/** @var IFormatter $message */
|
|
private $message = NULL;
|
|
|
|
public $action;
|
|
|
|
public $category = 'app';
|
|
|
|
/**
|
|
* 错误处理注册
|
|
*/
|
|
public function register()
|
|
{
|
|
ini_set('display_errors', 0);
|
|
set_exception_handler([$this, 'exceptionHandler']);
|
|
if (defined('HHVM_VERSION')) {
|
|
set_error_handler([$this, 'errorHandler']);
|
|
} else {
|
|
set_error_handler([$this, 'errorHandler']);
|
|
}
|
|
register_shutdown_function([$this, 'shutdown']);
|
|
}
|
|
|
|
/**
|
|
* @throws Exception
|
|
*/
|
|
public function shutdown()
|
|
{
|
|
$lastError = error_get_last();
|
|
if ($lastError['type'] !== E_ERROR) {
|
|
return;
|
|
}
|
|
|
|
$this->category = 'shutdown';
|
|
|
|
$messages = explode(PHP_EOL, $lastError['message']);
|
|
|
|
$message = array_shift($messages);
|
|
|
|
$this->sendError($message, $lastError['file'], $lastError['line']);
|
|
}
|
|
|
|
|
|
/**
|
|
* @param Exception $exception
|
|
*
|
|
* @throws Exception
|
|
*/
|
|
public function exceptionHandler($exception)
|
|
{
|
|
$this->category = 'exception';
|
|
|
|
$event = Snowflake::get()->event;
|
|
$event->trigger(Event::RELEASE_ALL);
|
|
|
|
$this->sendError($exception->getMessage(), $exception->getFile(), $exception->getLine());
|
|
}
|
|
|
|
/**
|
|
* @throws Exception
|
|
*
|
|
* 以异常形式抛出错误,防止执行后续程序
|
|
*/
|
|
public function errorHandler()
|
|
{
|
|
$error = func_get_args();
|
|
if (strpos($error[2], 'vendor/Reboot.php') !== FALSE) {
|
|
return;
|
|
}
|
|
|
|
$path = ['file' => $error[2], 'line' => $error[3]];
|
|
|
|
if ($error[0] === 0) {
|
|
$error[0] = 500;
|
|
}
|
|
|
|
$data = JSON::to(500, 'Error : ' . $error[1], $path);
|
|
|
|
Logger::error($data, 'error');
|
|
|
|
$event = Snowflake::get()->event;
|
|
$event->trigger(Event::RELEASE_ALL);
|
|
|
|
throw new \ErrorException($error[1], $error[0], 1, $error[2], $error[3]);
|
|
}
|
|
|
|
/**
|
|
* @param $message
|
|
* @param $file
|
|
* @param $line
|
|
* @param int $code
|
|
* @return false|string
|
|
* @throws Exception
|
|
*/
|
|
public function sendError($message, $file, $line, $code = 500)
|
|
{
|
|
$path = ['file' => $file, 'line' => $line];
|
|
|
|
$data = JSON::to($code, $this->category . ': ' . $message, $path);
|
|
|
|
Logger::trance($data, $this->category);
|
|
|
|
return print_r($data);
|
|
}
|
|
|
|
/**
|
|
* @return mixed
|
|
*/
|
|
public function getErrorMessage()
|
|
{
|
|
$message = $this->message;
|
|
$this->message = NULL;
|
|
return $message->getData();
|
|
}
|
|
|
|
/**
|
|
* @return bool
|
|
*/
|
|
public function getAsError()
|
|
{
|
|
return $this->message !== NULL;
|
|
}
|
|
|
|
/**
|
|
* @param $message
|
|
* @param $category
|
|
*
|
|
* @throws Exception
|
|
*/
|
|
public function writer($message, $category = 'app')
|
|
{
|
|
Logger::debug($message, $category);
|
|
}
|
|
}
|