Want to protect your cyber security and still get fast solutions? Ask a secure question today.Go Premium

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 437
  • Last Modified:

A PHP function equal to ASP's response.redirect?

Hi experts!

I've been playing around with the header() function in PHP, but I can't get it to work properly.

What I want is my own Redirect() function that I can call WHENEVER I want in my script. So the function should work even if there's already some HTML buffered or not.

I've also tried the http_redirect function, but it's not installed on the webserver at GoDaddy so I can't use that.

This is what my ASP function looks like:
<%
function redirect(tUrl)
	response.redirect tUrl
end function
%>

Open in new window

0
JoachimMartinsen
Asked:
JoachimMartinsen
1 Solution
 
Michael701Commented:
header is the correct function

header('location: /index.php');

here's the main problem people have.

there has to be NO OUTPUT to the browser before the header command. This include any 'white space' (blank lines before the <?PHP) It's also most important to check the include files for white space.
0
 
basic612Commented:
You could look in to output buffering if you wanted to avoid content being sent to the browser before you get a chance to send header redirect.

I'd suggest you could also send some javascript to the browser to carry out your header redirect in case your header one failed. The following function may be of assistance.

However, the best possible method is to ensure that you have not output anything to the browser, then you can send a header redirect which will be most transparent to the end user...

<?php
function custom_redirect($url)
        error_reporting(0); // hide errors if header sent already
        header($url);
        echo <<<EOD
<script type="text/javascript">
<!--
window.location = "$url"
//-->
</script>
EOD;
}
?>

Open in new window

0
 
basic612Commented:
sorry, typo in last code

<?php
function custom_redirect($url)
        error_reporting(0); // hide errors if header sent already
        header("Location: $url");
        echo <<<EOD
<script type="text/javascript">
<!--
window.location = "$url"
//-->
</script>
EOD;
}
?>

Open in new window

0
Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
Ray PaseurCommented:
You can also do this.  It works at any point in the code - it does not have to be in the HTML headers.  It has pretty good browser support and does not require JavaScript.

// REDIRECT
echo "<meta http-equiv=\"refresh\" content=\"0;url=$url" />\n";

Open in new window

0
 
basic612Commented:
While <META> tags may work for you in the body of the document, they actually belong in the <HEAD> according the the W3C reccomendations

As such I would not advise using the <META> tag in the <BODY> section as you are not guaranteed cross-browser compatibility.

Not any more so than using Javascript at any rate.

The safest method to provide consistent results is to use the headers to redirect, and ensure you do this before your script produces any output.
0
 
Ray PaseurCommented:
@basic612: Completely agree about using the header() command.  OTOH, the meta refresh and the JS methods will work for 95% or more of the clients.  And for the other 5% a link that says, "If you are not redirected, click here" should fill the bill.

Here is a sample of how to produce output that is destined for the browser output, and capture it in the output buffer, then redirect.  An important point to note is that in PHP, header("Location"); is a synchronous part of the script.  The header is sent to the browser and the SCRIPT KEEPS RUNNING.  So it is often very important to use die() or exit in order to stop the script and prevent unexpected consequences.  Omitting the exit statement after header("Location") is a common oversight.

Best regards, ~Ray
<?php // RAY_ob_redirect.php
error_reporting(E_ALL);
 
// START THE OUTPUT BUFFER TO PREVENT DATA FROM GOING TO THE BROWSER
ob_start();
 
// WRITE SOME DATA - THIS DOES NOT GO TO THE BROWSER, IT GETS CAUGHT IN THE BUFFER
echo "<br/>Click here if you are not redirected: <a href=\"http://google.com\">http://google.com</a>\n";
 
// REDIRECT - NOTE THAT THIS IS A SYNCHRONOUS COMMAND
// THE SCRIPT KEEPS RUNNING WHILE IT WAITS FOR THE BROWSER TO REDIRECT!!
header("Location: http://google.com");
 
// NOW FLUSH THE OUTPUT BUFFER
ob_end_flush();
 
// NOW THE SCRIPT IS DONE - YOU _MUST_ STOP THE SCRIPT AFTER A HEADER("Location:") COMMAND
die();

Open in new window

0
 
JoachimMartinsenAuthor Commented:
I kind of knew about this. However, you delivered a complete script for me to use.
0
 
Ray PaseurCommented:
Thanks for the points - it's a good question.  Best, ~Ray
0

Featured Post

Free Tool: IP Lookup

Get more info about an IP address or domain name, such as organization, abuse contacts and geolocation.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Tackle projects and never again get stuck behind a technical roadblock.
Join Now