Posted January 7, 201015 yr There’s a lot that you can do with an htaccess file, and of course, things can get pretty advanced in a hurry. Here, we’re going to keep things pretty simple. These are the 10 basic htaccess hacks that every webmaster should know. 1. Force Caching with htaccess Use: The following htaccess code won’t help the initial pageload, but it will significantly help subsequent pageloads by sending 304 status when requested elements haven’t been modified. FileETag MTime Size ExpiresActive on ExpiresDefault “access plus x seconds†I generally set the cache for one day (86400 seconds). You can also set different expirations for each file type by breaking each file type up into separate ExpiresByType lines such as: ExpiresByType image/gif “access plus x seconds†ExpiresByType text/css “access plus x seconds†Simple! 2. Set a Custom 404 Page with htaccess Use: I think this one is self explantatory. Just change ‘/notfound.html’ to match the path to your custom 404 page. ErrorDocument 404 /notfound.html 3. Implement a 301 Redirect with htaccess Use: If you have permanently changed the URL structure on your site (via either optimization change or CMS migration), you will want to implement 301 redirects from the old URL to the new URL. The syntax for a basic 301 redirect is: Redirect 301 relative/path/to/oldurl/ http://www.domain.com/newurl/ Explanation: The first URL should be a relative path to the old URL and the second one should be an absolute path to the new URL. 4. Only allow specific IP addresses in certain directories This is especially useful for admin directories. I generally set my home IP and work IP as the only allowable IPs who can even attempt a login. Unlike other .htaccess hacks, this one doesn’t work from the root folder. You will need to create a new .htaccess file, put the following code in it, and upload it to your admin directory. AuthUserFile /dev/null AuthGroupFile /dev/null AuthName “Example Access Control†AuthType Basic order deny,allow deny from all allow from xx.xx.xx.xx To allow a second IP, just add another ‘allow from’ line. 5. Prevent Image Hot Linking with htaccess If you check your server logs with any frequency, you’ve undoubtedly seen an image that you’re paying to host hotlinked on some crazy popular forum somewhere and your bandwidth goes down the crapper. Now, if you wish, you can prevent hotlinking altogether. But I’d rather take advantage of the opportunity and throw a 2kb gif with my URL out there to hit some new eyeballs. To do this, you just have to replace the requested image with a new one. This code simply declares the extensions of files you would like to protect, and rewrites the requested URL to your image path if the domain is not yours. The [NC] command means that the preceeding string is not case sensitive. The [L] command means that it is the last rule that your htaccess should execute on this request. RewriteEngine on RewriteCond %{HTTP_REFERER} !^$ RewriteCond %{HTTP_REFERER} !^http://(www\.)?yourdomain.com(/)?.*$ [NC] RewriteRule \.(gif|jpe?g|png|bmp)$ /images/humiliatingimage.gif [L,NC] 6. Enable gzip with htaccess Gzip is a means of compressing the files on your server so they will load faster. To enable gzip, just AddOutputFilterByType DEFLATE text/html text/plain text/xml application/xml application/xhtml+xml text/javascript text/css application/x-javascript BrowserMatch ^Mozilla/4 gzip-only-text/html BrowserMatch ^Mozilla/4.0[678] no-gzip BrowserMatch bMSIE !no-gzip !gzip-only-text/html 7. Remove ‘category’ from a URL with htaccess Many content management sytems use the ‘category’ URL segment. For instance: http://makeitrank.com/category/category-name Well, that’s fine, and it’s necessary to make the CMS work the way it’s supposed to, but it doesn’t need to be visible to do its job. Just drop the following code into your htaccess file to get rid of it. RewriteRule ^category/(.+)$ http://www.yourdomain.com/$1 [R=301,L] 8. Define any page as the home page with htaccess You can set any page as the homepage by adding the following to the htaccess file in your root directory. DirectoryIndex myfile 9. Disable Directory Browsing You want to keep people out of any directories that might reveal security weaknesses — for instance, plugin directories. You can block vistors from browsing the directories by adding the following line to the htaccess file in the directory you’d like to block: Options All -Indexes 10. Protect your htaccess file Lastly, you want to protect your htaccess file. Hopefully your host has protected it for you, but you can’t be too safe with these things. The following hack will prevent anybody from accessing your htaccess: order allow,deny deny from all satisfy all Are there any useful htaccess hacks I’ve left out? Let me know! [Source..]
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.