标签(空格分隔): php, thinkphp5

  1. namespace app\common\exception;
  2. use think\Exception;
  3. class ApiException extends Exception
  4. {
  5. public $code = 0;
  6. public $message = 'invalid parameters';
  7. public function __construct($params = [])
  8. {
  9. if (!is_array($params)) return;
  10. if (array_key_exists('code', $params)) $this->code = $params['code'];
  11. if (array_key_exists('msg', $params)) $this->message = $params['msg'];
  12. }
  13. }

  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: ywf
  5. * Date: 2019/5/16
  6. * Time: 11:13
  7. */
  8. namespace app\common\exception;
  9. use think\Log;
  10. class MyHttpException extends \think\exception\Handle
  11. {
  12. public function render(\Exception $e)
  13. {
  14. if (config('app_debug')) return parent::render($e);
  15. if ($e instanceof ApiException) {
  16. return json([
  17. 'code' => $e->code,
  18. 'msg' => $e->message,
  19. ]);
  20. }
  21. $this->recordErrorLog($e);
  22. return json([
  23. 'code' => 500,
  24. 'msg' => $e->getMessage() ? : 'sorry server internal error!',
  25. 'file' => $e->getFile(),
  26. 'line' => $e->getLine(),
  27. ]);
  28. }
  29. /**
  30. * 记录异常日志
  31. * @param \Exception $e
  32. */
  33. private function recordErrorLog(\Exception $e)
  34. {
  35. Log::record($e->getMessage(), 'error');
  36. Log::record($e->getFile() . ' : ' . $e->getLine() . '行', 'error');
  37. Log::record($e->getTraceAsString(), 'error');
  38. }
  39. }

版权声明:本文为yanweifeng原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/yanweifeng/p/10950424.html