HTACCESS: Difference between revisions
No edit summary |
No edit summary |
||
Line 1: | Line 1: | ||
==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=== | |||
.htaccess files | 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. | ||
==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: | |||
<pre> | |||
# go away! | |||
RewriteEngine On | |||
RewriteCond %{HTTP_REFERER} ^http://badsite.com(.*)$ [NC] RewriteRule ^.* - [F,L] | |||
</pre> | |||
====Enable or disable error reporting in PHP==== | |||
Add the following lines to your .htaccess file to enable error reporting: | |||
<pre> | |||
Options +FollowSymlinks | |||
RewriteEngine on | |||
php_flag display_errors on | |||
php_value error_reporting 7 | |||
</pre> | |||
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: | |||
<pre> | |||
php_value display_errors 0 | |||
</pre> | |||
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. | |||
<pre> | |||
php_value register_globals 1 | |||
</pre> | |||
====Limiting access to your website based by IP address==== | |||
Add the following to a .htaccess file in the directory you want to protected: | |||
<pre> | |||
# 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. | |||
====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: | |||
<pre> | |||
Options +MultiViews | |||
</pre> | |||
Now, for example, instead of seeing <tt>http://yoursite.com/dem.php?forum=1</tt> you would see <tt>http://yoursite.com/dem?forum=1</tt>. 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: | |||
<pre> | |||
AddType application/x-java-jnlp-file JNLP | |||
</pre> | |||
====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. | |||
<pre> | |||
# enable compression for everything | |||
SetOutputFilter DEFLATE | |||
</pre> | |||
===Resources=== | |||
[http://www.htaccesstools.com/] | |||
*This website has an excellent .htaccess generator, and more information about .htaccess files. | |||
[http://www.htaccesseditor.com/] | |||
* Another tool to create .htaccess files | |||
[http://httpd.apache.org/docs/2.3/misc/rewriteguide.html] | |||
* Apache's rewrite guide has more information on using rewrite rules. | |||
http:// | |||
* | |||
Revision as of 15:32, 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.
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. ====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: <pre> 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.