Error handling

Reply

Join Date: Dec 2007
Posts: 3
Reputation: tony.willson is an unknown quantity at this point 
Solved Threads: 0
tony.willson tony.willson is offline Offline
Newbie Poster

Error handling

 
0
  #1
Dec 9th, 2007
We struggle to come up with a decent error handling function. I thought that I use a global variable $live to easily make a switch from testing to live. I will keep the function in an include file.
I kind of got there to print a "user-friendly" message when the site is live, but it messes up the whole page layout. Don't how to print the error message in the content area. How would I adjust my error handler and what would I add to "<?php require_once $content; ?>"?

My error handler:
<?php
/*-- start output buffering--*/
ob_start();
/*-- live site --*/
$live=TRUE;
/*-- error handling function giving back error number, the actual message, the error file, the error line and the variables (what are variable in this context?) --*/
function my_error_handler ($e_number, $e_message, $e_file, $e_line, $e_vars) {
/*-- make $live global --*/
global $live;
/*-- set error message for testing together --*/
$message="Error in file '$e_file' on line $e_line: $e_message\n";
$message.=print_r($e_vars,1);
/*-- error message for live site should not give any detail about problem, just an apology --*/
if($live){
$user="We apologise for the problems on this page...";
/*-- if there are error messages print the standard user message --*/
if ($message==0){echo $user;}else{
/*-- otherwise say 'hi there' --*/
echo ('');}
/*-- do it only once as user should not see the apology more than once --*/
exit();
} else {
/*-- if site is in testing print the acual error messages --*/
echo '<div class="error">'.$message.'</div><br/>';
}
}
ob_end_flush();
/*-- as everything is defined now, set the error handler, so it's ready to be used --*/
set_error_handler('my_error_handler');
?>

Also, in the bit "if ($message==0)" I would have thought that comparing $message to 1 would have printed the user-friendly error message (as I thought 1 means that there is one or more error message).


Any help appreciated.
Reply With Quote Quick reply to this message  
Join Date: Dec 2007
Posts: 113
Reputation: hielo is on a distinguished road 
Solved Threads: 17
hielo hielo is offline Offline
Junior Poster

Re: Error handling

 
0
  #2
Dec 9th, 2007
>>Don't how to print the error message in the content area
You need to trigger the error only while printing the content. For example the code below will NOT print it within the content because you are not triggering the error within the content:
  1. <?php
  2. $x = (int)$_POST['INPUT'];
  3. if( $x==3)
  4. trigger_error("Incorrect input vector, array of values expected", E_USER_WARNING);
  5.  
  6. ?>
  7. <html>
  8. <body>
  9. <?php
  10. getContent();
  11. ?>
  12. </body>
  13. </html>

You can work around it by simply setting a variable to TRUE if trigger_error should be called, but delay the call until the content.

  1. <?php
  2. global $triggerIt=FALSE;
  3. $x = (int)$_POST['INPUT'];
  4. if( $x==3)
  5.  
  6. ?>
  7. <html>
  8. <body>
  9. <?php
  10. if( TRUE==$triggerIt)
  11. {
  12. trigger_error("Incorrect input vector, array of values expected", E_USER_WARNING);
  13. }
  14. else
  15. {
  16. ?>
  17. getContent();
  18. <?php
  19. }
  20. ?>
  21. </body>
  22. </html>

You would also need to put:
global $triggerIt=FALSE;

in the same file where you are defining your errorHandler function. IF you are using some sort of templating system, then the
if( TRUE==$triggerIt){...}else{...}

part would be placed in the template. On my example, the getContent() should be a function defined on a per-page basis that returns the content for the page in question as a string. However, if you are using some third-party templating system, you would need to find out how they are emitting the content.

Short answer to your question, I believe you are triggering the error_handler outside of the content. In case you haven't seen it, there is a sample error handler at:
http://us2.php.net/manual/en/functio...or-handler.php
Reply With Quote Quick reply to this message  
Reply

This thread is more than three months old.
Perhaps start a new thread instead?
Message:


Thread Tools Search this Thread



About Us | Contact Us | Advertise | DaniWeb | Acceptable Use Policy | RSS Feed

©2003 - 2009 DaniWeb® LLC