Catching a failed require_once that gets page from a function

Posted on 2008-10-10
Last Modified: 2008-10-14
I'm working on a new function that builds my output page to separate my code from my content when I ran into a snag--my normal line of thinking doesn't work.

My cheap and easy was to deal with a failed require_once is to toss the user to the 404 like so:
            header('Location: http://intranet/404.php');

But when my require_once is the output of a function rather than a file, my normal trick doesn't work:
            header('Location: http://intranet/404.php');

The IF statement returns a fatal error when the $SITE->displayoutput() function doesn't exist.

Help my fried brain, how do I change my code to catch when require_once's target function fails/doesn't exist. I purposely have my singleton include commented out to force the failure so I can learn how to catch it.
	/* commented out to force the next step to fail
	   to learn how to catch the failure
		//Get the SITE Singleton
			header('Location: http://intranet/404.php');
	//Get the output from the SITE Singleton
		header('Location: http://intranet/404.php');

Open in new window

Question by:dban00b
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
LVL 39

Accepted Solution

Roger Baklund earned 500 total points
ID: 22691778
Try using isset() and method_exists(), something like this:

if(isset($SITE) and 
   method_exists($SITE,'displayoutput') and 
                header('Location: http://intranet/404.php');

Open in new window


Author Comment

ID: 22711907
Those two extra functions do indeed catch it! Thanks.

Featured Post

Secure Your WordPress Site: 5 Essential Approaches

WordPress is the web's most popular CMS, but its dominance also makes it a target for attackers. Our eBook will show you how to:

Prevent costly exploits of core and plugin vulnerabilities
Repel automated attacks
Lock down your dashboard, secure your code, and protect your users

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Popularity Can Be Measured Sometimes we deal with questions of popularity, and we need a way to collect opinions from our clients.  This article shows a simple teaching example of how we might elect a favorite color by letting our clients vote for …
Nothing in an HTTP request can be trusted, including HTTP headers and form data.  A form token is a tool that can be used to guard against request forgeries (CSRF).  This article shows an improved approach to form tokens, making it more difficult to…
Explain concepts important to validation of email addresses with regular expressions. Applies to most languages/tools that uses regular expressions. Consider email address RFCs: Look at HTML5 form input element (with type=email) regex pattern: T…
The viewer will learn how to count occurrences of each item in an array.

690 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question