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!
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.
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.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With