Jump to content

Featured Replies

Posted

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.

Guest
Reply to this topic...