Is there a way to redirect from my Facebook canvas page to my external website? I've seen blogs and stackoverflow answers of the form:
<script>
window.top.location = 'http://www.yoursite.com/';
</script>
Unfortunately these kinds of solutions never work. I've tried top.location.href, window.location and location.href as well.. nothing works. Did Facebook remove the possibility to redirect from javascript by parsing out this kind of code? Is there a way to still redirect?
UPDATE: What happens is the webpage acts like there was never a javascript redirect instruction. And in fact, when I look at the source code through firebug I see no javascript redirects.
UPDATE 2: I get the following javascript errors form my canvas page when I try window.top.location = 'http://www.yoursite.com/';
and the other variations above. It seems Facebook doesn't allow access to the window, top or location global javascript variables:
Uncaught ReferenceError: a217374027657_location is not defined
Uncaught ReferenceError: a217374027657_window is not defined
Uncaught ReferenceError: a217374027657_top is not defined
Interestingly, document.location = 'http://www.yoursite.com/';
works in that there are no exceptions... but of course the webpage doesn't get redirected.
UPDATE 3: Figured it out! Javascript redirect only works with iframe canvases. I had to change my settings in the advanced screen to use iframe instead of FBML.
From my script
And it always worked. Does it throw any error, exception or so?
If you can use PHP, try to
die()
after this javascript codeThis is not possible, Facebook disabled this functionality on purpose. You'd either have to stay in your canvas, open a popup (if possible) or just create a link for the user to click on.
Beware, redirecting the user to an external site can violate the platform policy
how about using the following code:
I just did this on my app:
Just place that on the top of your canvas page. If the top href doesn't match the url your canvas content is pulled from, it redirects to your site.