HTACCESS: Difference between revisions
Line 82: | Line 82: | ||
<pre> | <pre> | ||
# allow access to just two ips | # allow access to just two ips | ||
Order Allow,Deny | |||
# my home ip, my work ip | # my home ip, my work ip | ||
allow from 168.55.55.11 58.66.12.79 | allow from 168.55.55.11 58.66.12.79 | ||
</pre> | |||
Be careful as you may lock yourself out of your own site. If this happens, you can always access your site with a ftp program or with our File Manager tool and remove or modify the .htaccess file. | Be careful as you may lock yourself out of your own site. If this happens, you can always access your site with a ftp program or with our File Manager tool and remove or modify the .htaccess file. | ||
Similarly, to block people from specific ip addresses from accessing your site, you could add the following to your .htaccess file: | |||
<pre> | |||
# Block all access from 192.168.10.5 | |||
Order Deny,Allow | |||
Deny from 192.168.10.5 | |||
</pre> | |||
====Hide .php extensions to make your website address look cleaner==== | ====Hide .php extensions to make your website address look cleaner==== |
Revision as of 15:42, 3 March 2008
What Is It?
.htaccess is a plain text file used to customize some web server settings for your website. It applies a set of configuration options to all files in the directory that the file is located. In addition, these options will also apply to subdirectories of that directory, unless a separate .htaccess file in those directories contains different settings.
Cautions
It is important to follow these guidelines when editing .htaccess files:
- The filename must be exactly .htaccess - you can not use any other filename.
- If you have problems renaming a file to .htaccess in windows, open the file in Notepad, Choose "Save as.." and select "All types (*.*)" next to file type. Now type the filename ".htaccess" and click save.
- Any rules you set by .htacess will apply to all files in the directory you have placed the .htaccess file, and any of its subdirectories. The .htaccess rules in the current directory will override any .htaccess rules set in a parent directory.
- Any typos or mistakes in a .htaccess file will may result in an HTTP 500 server error being returned when you try to visit that directory, and may render your entire site offline. If this happens, you can still access your site with the File Manager on your Bravenet.com website manager, or with any FTP program.
- .htaccess files are very picky about what you put in them so please be careful to use exact syntax.
- Do not attempt to turn PHP safe mode off in a .htaccess file - this will not work and will cause your site to no longer load until you undo the change.
Other Questions
I can't see the .htaccess file in my FTP program. Any file that starts with a '.' is considered a hidden file on Unix systems. Some FTP programs will not show these 'dot files' by default. Here's some instructions on how to enable hidden files for some of the more popular FTP programs:
- FileZilla
- View -> Show hidden files.
- Cute FTP
- Open the Site Manager (press F4) and click on the name of the relevant site.
- Click the Actions tab, then click Filter.
- Select the Enable Filtering check box.
- In Server side filtering, select the Enable Server Side Filtering check box.
- In the Remote Filter box, type -a.
- Click OK, then click Connect.
- WS_FTP Pro (7.62)
- Sites
- Organize sites
- Site options
- Startup tab
- In Remote Filter Mask box enter -a
Remember, you can always use the File Manager on our web site manager page to easily upload, download, or even edit your .htaccess files.
Using htaccess To...
Block another website from linking to yours
Add the following to a .htaccess file in the directory containing the files you want to protect, and change the text "badsite.com" to be the exact name of the website you want to block:
# go away! RewriteEngine On RewriteCond %{HTTP_REFERER} ^http://badsite.com(.*)$ [NC] RewriteRule ^.* - [F,L]
Enable or disable error reporting in PHP
Add the following lines to your .htaccess file to enable error reporting:
Options +FollowSymlinks RewriteEngine on php_flag display_errors on php_value error_reporting 7
We have display_errors set to "on" by default for all users - this is to help inform you of problems when you are working on your site. You may want to turn that off when you are ready to show your site off to the world - use the following to disable errors:
php_value display_errors 0
When errors are disabled, the visitor will only see a blank page when an error is encountered, instead of several lines of PHP code and error messages.
Enable the "Register Globals" PHP flag
Add the following only if your PHP code specifically requires this setting. It does have some security implications, so you should only use it if you need to. In addition, this setting will no longer be an option once PHP 6.0 is released, so please consider staying clear of PHP code that requires this setting.
php_value register_globals 1
Limiting access to your website based by IP address
Add the following to a .htaccess file in the directory you want to protected:
# allow access to just two ips Order Allow,Deny # my home ip, my work ip allow from 168.55.55.11 58.66.12.79
Be careful as you may lock yourself out of your own site. If this happens, you can always access your site with a ftp program or with our File Manager tool and remove or modify the .htaccess file.
Similarly, to block people from specific ip addresses from accessing your site, you could add the following to your .htaccess file:
# Block all access from 192.168.10.5 Order Deny,Allow Deny from 192.168.10.5
Hide .php extensions to make your website address look cleaner
If you want to hide .php extensions to make your site appear more "clean" you can add the following to a .htaccess file:
Options +MultiViews
Now, for example, instead of seeing http://yoursite.com/dem.php?forum=1 you would see http://yoursite.com/dem?forum=1. Be careful with this though, as it can lead to unexpected results. As always, test your changes thoroughly!
Add a MIME type to the webserver
Adding a MIME type to the server allows visitors to your website to be prompted to open files directly into the correct application. For example, if you have some java programs on your website, and want visitors to be able to run those programs directly in Java webstart, you would add the following to your .htaccess file:
AddType application/x-java-jnlp-file JNLP
Enable compression for PHP files
Bravenet use compression on certain files to make downloading websites a lot faster. However, some files we leave uncompressed to avoid certain errors. If you would like to enable compression on everything, add the following to your .htaccess file. Make sure to test your entire site if you enable this option - some code does not like this setting.
# enable compression for everything SetOutputFilter DEFLATE
Resources
- This website has an excellent .htaccess generator, and more information about .htaccess files.
- Another tool to create .htaccess files
- Apache's rewrite guide has more information on using rewrite rules.