この記事は、CodeIgniter3.0 フレームワークのカスタム例外処理メソッドの紹介です。一定の参考価値があります。必要な友人は参照してください。お役に立てれば幸いです。
背景: ci3.0 フレームワークのコア コードは、例外を自動的に実装し、スローされる対応するページとメソッドを実装します。これは、一部の個人化されたニーズ、特にインターフェイス タイプのアプリケーションには適さない可能性があります。したがって、コアコード (システムディレクトリ内のファイル) を変更することなく、例外および 404 およびその他の関連例外の処理を変更する必要があります。
メソッドの説明
CI フレームワーク 3.0 には 2.0 と比較して大きな変更があり、その 1 つは例外の処理です。以下は、CodeIgniter-3.1.8\system\core\CodeIgniter.php
/* * ------------------------------------------------------ * Define a custom error handler so we can log PHP errors * ------------------------------------------------------ */ set_error_handler('_error_handler'); set_exception_handler('_exception_handler'); register_shutdown_function('_shutdown_handler'); ...
の例外処理のコードの一部です。上記の括弧内のメソッドはすべて、common の
で始まります。 php function_exists
は前提条件のステートメントです。
... if ( ! function_exists('_exception_handler')) { ...
プロジェクト エントリ ファイルの次のメソッドを単純かつ大まかに書き換えます index.php
/** * 推送到redis 异常队列 * @time 2019/3/21 15:29 * @author * @param $msg * @return bool|int|string */ function redis_list_add($msg) { ini_set('default_socket_timeout', -1); $v = explode(':', $_SERVER['SITE_REDIS_SERVER']); if (is_array($v) && !empty($v)) { try { $redis = new redis(); $redis->pconnect($v[0], $v[1]); $trace = $_SERVER['SERVER_NAME'] . " exception\n"; $trace .= "clint ip is {$_SERVER['REMOTE_ADDR']} " . ",server is " . $_SERVER['SERVER_NAME'] . "(" . $_SERVER['SERVER_ADDR'] . ")"."\n"; $trace.= "path is ".(isset($_SERVER['REQUEST_URI'])?$_SERVER['REQUEST_URI']:"empty")."\n"; $trace .= "request params is =" . print_r($_POST, true); return $redis->LPUSH('PHP_ERROR_WARNING', $trace . $msg); } catch (Exception $e) { return $e->getMessage(); } } } /** * 优先重写common.php中对应方法 * @time 2019/3/21 16:19 * @author * @param $severity * @param $message * @param $filepath * @param $line */ function _error_handler($severity, $message, $filepath, $line) { $is_error = (((E_ERROR | E_PARSE | E_COMPILE_ERROR | E_CORE_ERROR | E_USER_ERROR | E_STRICT) & $severity) === $severity); if ($is_error) { $error_msg = ($message . "\n" . $filepath . "\n" . $line); redis_list_add($error_msg); exit(json_encode(['success' => '-1', 'code' => 501, 'msg' => 'error'])); } } /** * 捕获php本身语法,对象调用,参数类型传递等错误 * 优先重写common.php中对应方法 * ParseError,object(Error),TypeError,Error * @time 2019/3/20 18:33 * @author * @param $exception */ function _exception_handler($exception) { $_tmp =& load_class('Exceptions', 'core'); if (!empty($exception)) { $error_msg = ($exception->getMessage() . "\n" . $exception->getTraceAsString()); redis_list_add($error_msg); exit(json_encode(['success' => '-1', 'code' => 501, 'msg' => 'exception'])); } } /** * 优先重写common.php中对应方法 * require_once('no_exists.php') * @time 2019/3/21 9:49 * @author */ function _shutdown_handler() { $last_error = error_get_last(); if (isset($last_error) && ($last_error['type'] & (E_ERROR | E_PARSE | E_CORE_ERROR | E_CORE_WARNING | E_COMPILE_ERROR | E_COMPILE_WARNING))) { redis_list_add($msg = $last_error['message'] . "\n" . $last_error['file'] . "\n" . $last_error['line'] . "\n"); exit(json_encode(['success' => '-1', 'code' => 501, 'msg' => 'shutdown'])); } } /** * 优先重写common.php中对应方法 * ci 框架内部的load异常、config异常、loader异常等会自动抛出, * 但common.php中的函数定义之类错误无法捕捉 * @time 2019/3/20 18:46 * @author * @param $message * @param int $status_code */ function show_error($message) { redis_list_add($message); exit(json_encode(['success' => '-1', 'code' => '503', 'msg' => 'ci_exception_1'])); } /** * 优先重写common.php中对应方法 * @time 2019/3/21 15:34 * @author * @param string $page */ function show_404($page = '') { redis_list_add("url: " . $page . " not found"); exit(json_encode(['success' => '-1', 'code' => '404', 'msg' => 'Not Found'])); }
この記事はここで終わりですその他のエキサイティングなコンテンツについては、PHP 中国語 Web サイトの PHP ビデオ チュートリアル 列に注目してください。
以上がCodeIgniter3.0+ フレームワークのカスタム例外処理メソッドの紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。