Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

htaccess redirect vs php redirect

Tags:

php

seo

I have decided to change all my /dyanmic.php?UID=... pages to /static/Name-From-DB. I have read that the best way to do redirection, SEO wise, is to implement a 301 .htacess redirection:

(http://www.tamingthebeast.net)- The right way - a htaccess 301 Redirect: A 301 redirect is the most efficient and spider/visitor friendly strategy around for web sites that are hosted on servers running Apache.

However, since I have thousands of pages I need to use redirection for, it seems pretty inefficient to have thousands of entries in the .htacess file:

redirect 301 /dynamid.php?UID=1 http://www.domain.com/static/Name-From-DB
redirect 301 /dynamid.php?UID=2 http://www.domain.com/static/Another-Name-From-DB
and so on...

Therefore it seems like the efficient way to do it is via the PHP page, setting the header to 301 redirection according to the UID:

<?
Header( "HTTP/1.1 301 Moved Permanently" ); 
// Getting the page static name from the DB according to the UID
$result = mysql_query('SELECT Name FROM DB WHERE UID='$_GET["uid"]'');
$row=mysql_fetch_assoc($result);
// Redirect to the new page
Header( "Location: http://www.domain.com/static/" . $row[0] ); 
?> 

My question is if this method will effect in a negative way on my pages' rankings, considering the paragraph I quoted above that the best way to do a redirection is through the .htaccess.

Thanks!

like image 647
Joel Avatar asked Nov 04 '10 08:11

Joel


Video Answer


2 Answers

The same headers will be sent the same whichever way you do it. Therefore, to the user (or to a search engine) it won't be any different so the PHP won't negatively effect your page rank compared to the .htaccess way.

The PHP way will be a little bit slower as every time the page is accessed a database query is fired off. If the site doesn't have too much traffic going to those pages it shouldn't be an issue though.

In your PHP page, do the database connection first because if the page doesn't exist you will want to either redirect them to another page or pass 404 error headers instead of the 301 header.

like image 55
drew Avatar answered Nov 15 '22 12:11

drew


My question is if this method will effect in a negative way on my pages' rankings, considering the paragraph I quoted above that the best way to do a redirection is through the .htaccess.

No, it will not provided that you implement the redirection correctly in your PHP file! I.e., you should probably look up the Name (by uid) before issuing the 301 header (and only issue this when a Name is found — otherwise it's a 404).

Also, why don't you run a query on your database, output the redirects in .htaccess format and write this directly to the .htaccess file? This way you'll have to do it only once and wont have to care about non-existing uid's.


Edit — pseudocode

str ← ""
for each (uid, Name) in database:
    line ← concat("Redirect 301 /dynamid.php?UID=", uid, "http://www.domain.com/static/", Name, <newline>)
    append line to str
copy or write str to .htaccess

Doing this, you'll still be able to find your redirects in a year (they're all in .htaccess) and there's no longer a need to do a look-up in the database on every "old style" request.

like image 24
jensgram Avatar answered Nov 15 '22 12:11

jensgram