מדריך PHP
קודם
הבא
There are several types of errors and warnings in PHP.
They are:
טבלה 15-1.
PHP error types
Value
Constant
Description
Note
1
E_ERROR
fatal run-time errors
2
E_WARNING
run-time warnings (non fatal errors)
4
E_PARSE
compile-time parse errors
8
E_NOTICE
run-time notices (less serious than warnings)
16
E_CORE_ERROR
fatal errors that occur during PHP 's initial startup
PHP 4 only
32
E_CORE_WARNING
warnings (non fatal errors) that occur during PHP 's initial startup
PHP 4 only
64
E_COMPILE_ERROR
fatal compile-time errors
PHP 4 only
128
E_COMPILE_WARNING
compile-time warnings (non fatal errors)
PHP 4 only
256
E_USER_ERROR
user-generated error message
PHP 4 only
512
E_USER_WARNING
user-generated warning message
PHP 4 only
1024
E_USER_NOTICE
user-generated notice message
PHP 4 only
E_ALL
all of the above, as supported
The above values (either numerical or symbolic) are used to build up a bitmask that specifies which errors to report.
You can use the bitwise operators to combine these values or mask out certain types of errors.
Note that only '|', '~',' !', and '' will be understood within php.ini, however, and that no bitwise operators will be understood within php3.ini.
In PHP 4, the default error_reporting setting is E_ALL ~E_NOTICE, meaning to display all errors and warnings which are not E_NOTICE-level.
In PHP 3, the default setting is (E_ERROR | E_WARNING | E_PARSE), meaning the same thing.
Note, however, that since constants are not supported in PHP 3' s php3.ini, the error_reporting setting there must be numeric; hence, it is 7.
The initial setting can be changed in the ini file with the error_reporting directive, in your Apache httpd.conf file with the php_error_reporting (php3_error_reporting for PHP 3) directive, and lastly it may be set at runtime within a script by using the error_reporting() function.
אזהרה
When upgrading code or servers from PHP 3 to PHP 4 you should check these settings and calls to error_reporting() or you might disable reporting the new error types, especially E_COMPILE_ERROR.
This may lead to empty documents without any feedback of what happened or where to look for the problem.
All PHP expressions can also be called with the "@" prefix, which turns off error reporting for that particular expression.
If an error occurred during such an expression and the track_errors feature is enabled, you can find the error message in the global variable $php_errormsg.
הערה:
The @ error-control operator prefix will not disable messages that are the result of parse errors.
אזהרה
Currently the @ error-control operator prefix will even disable error reporting for critical errors that will terminate script execution.
Among other things, this means that if you use @ to suppress errors from a certain function and either it isn 't available or has been mistyped, the script will die right there with no indication as to why.
Below we can see an example of using the error handling capabilities in PHP.
We define a error handling function which logs the information into a file (using an XML format), and e-mails the developer in case a critical error in the logic happens.
דוגמה 15-1.
Using error handling in a script
?php / / we will do our own error handling error_reporting( 0); / / user defined error handling function function userErrorHandler ($errno, $errmsg, $filename, $linenum, $vars) {/ / timestamp for the error entry $dt = date("Y-m-d H:i:s (T)"); / / define an assoc array of error string / / in reality the only entries we should / / consider are 2,8,256,512 and 1024 $errortype = array (1 = "Error", 2 = "Warning", 4 = "Parsing Error", 8 = "Notice", 16 = "Core Error", 32 = "Core Warning", 64 = "Compile Error", 128 = "Compile Warning", 256 = "User Error", 512 = "User Warning", 1024= "User Notice "); / / set of errors for which a var trace will be saved $user_errors = array(E_USER_ERROR, E_USER_WARNING, E_USER_NOTICE); $err =" errorentry \n"; $err .= "\t datetime ".$dt. "/ datetime \n"; $err .= "\t errornum ".$errno." / errornum \n"; $err .= "\t errortype ".$errortype[$errno]. "/ errortype \n"; $err .= "\t errormsg ".$errmsg." / errormsg \n"; $err .= "\t scriptname ".$filename. "/ scriptname \n"; $err .= "\t scriptlinenum ".$linenum." / scriptlinenum \n"; if (in_array($errno, $user_errors)) $err .= "\t vartrace ".wddx_serialize_value($vars ,"Variables"). "/ vartrace \n"; $err .=" / errorentry \n\n"; / / for testing / / echo $err; / / save to the error log, and e-mail me if there is a critical user error error_log($err, 3, "/ usr / local / php4 / error.log"); if ($errno == E_USER_ERROR) mail("phpdev@example.com" ,"Critical User Error",$err);} function distance ($vect1, $vect2) {if (!is_array($vect1) | | !is_array($vect2)) {trigger_error("Incorrect parameters, arrays expected", E_USER_ERROR); return NULL;} if (count($vect1) != count($vect2)) {trigger_error("Vectors need to be of the same size", E_USER_ERROR); return NULL;} for ($i=0; $i count($vect1); $i++) {$c1 = $vect1[$i]; $c2 = $vect2[$i]; $d = 0.0; if (!is_numeric($c1)) {trigger_error("Coordinate $i in vector 1 is not a number, using zero", E_USER_WARNING); $c1 = 0.0;} if (!is_numeric($c2)) {trigger_error("Coordinate $i in vector 2 is not a number, using zero", E_USER_WARNING); $c2 = 0.0;} $d += $c2*$c2 - $c1*$c1;} return sqrt($d);} $old_error_handler = set_error_handler("userErrorHandler"); / / undefined constant, generates a warning $t = I_AM_NOT_DEFINED; / / define some "vectors" $a = array(2,3 ,"foo"); $b = array(5.5, 4.3, -1.6); $c = array (1,-3); / / generate a user error $t1 = distance($c,$b) ."\n"; / / generate another user error $t2 = distance($b ,"i am not an array") ."\n"; / / generate a warning $t3 = distance($a,$b) ."\n";?
See also error_reporting(), error_log(), set_error_handler(), restore_error_handler(), trigger_error(), user_error()
קודם
ראשי
הבא
תכונות
למעלה
יצירה ועיצוב של תמונות