之前讲到过对于异常的处理机制,最好可以自定义异常,如果debug打开,那么显示具体的调试信息,如果debug关闭,那么将异常记录到日志,然后跳转到错误页,这节课我就主要来讲一下这个异常处理机制。
现在我们定义一个异常的基类,在Toper中为Tp_Exception,在这儿,我就直接叫BaseException吧,那BaseException.php肯定首先是有一个架子的:
1 |
2 | class BaseException extends Exception { |
3 | public function printStack() { |
4 |
5 | } |
6 | public function __toString() { |
7 |
8 | } |
9 | } |
最基础的,这个类肯定要继承自Exception,然后我需要实现__toString方法和另外一个自定义的printStack方法,实现__toString方法的原因是经常我们会直接throw new Exception() 这种方式抛出异常,它会直接调用__toString()方法,调用printStack方法就是输出堆栈信息。
说一下思路,首先这两个方法我们都需要判定是否是debug模式,如果是debug模式,那么很easy,直接输出即可,否则,跳转到错误页,但是跳转之前,必须要将异常信息写入到日志文件中去。
可能大家注意到,不管是__toString还是printStack如果debug关闭,都需要记录调试信息到日志文件,所以我们需要首先编写一个辅助函数:
1 | protected function _toLogFile($str) { |
2 | file_put_contents(APP_PATH . '/log',$str,FILE_APPEND); |
3 | } |
这儿,为了简便,我就直接使用file_put_contents了,这个函数功能很强大啊,我特别喜欢~~
由于到目前还没有讲URL重定向,转发请求等,暂时就直接显示错误页,所以又需要有一个辅助函数:
1 | protected function _outputErrorPage() { |
2 | header("content-type:text/html"); |
3 | echo file_get_contents(APP_PATH . '/error.html'); |
4 | } |
因为要求代码简单,所以错误页和日志文件都直接写死到项目根目录中,如果你有兴趣,可以自己试着将路径写在配置文件中,这个也不是很难的。
由于辅助函数已经写完,所以其他两个函数就很easy了:
1 | public function printStack() { |
2 | if(true === C('debug')) { |
3 | echo parent::getTraceAsString(); |
4 | } else { |
5 | $this->_toLogFile(parent::getTraceAsString()); |
6 | $this->_outputErrorPage(); |
7 | } |
8 | } |
1 | public function __toString() { |
2 | if(true !== C('debug')) { |
3 | $this->_toLogFile(parent::getTraceAsString()); |
4 | $this->_outputErrorPage(); |
5 | exit(); |
6 | } |
7 | return parent::__toString(); |
8 | } |
当然,由于__toString要返回字符串,而一旦throw一个异常,就会直接显示出来异常信息,为了在debug关闭之后不在页面显示异常信息,所以就直接在此处exit了,当然,我目前没有想到一个更好的办法,所以建议使用printStack来做。
我这个异常类就是用来抛砖引玉的,所以如果你有什么好的方法,请和我多多交流,互相学习,互相成长。
当然,现在只是定义了一个异常处理的基类,后面会写很多关于异常的子类,真正使用的时候是调用其子类的。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3漢化版
中文版,非常好用

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

WebStorm Mac版
好用的JavaScript開發工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。