HTACCESS: Difference between revisions
mNo edit summary |
|||
(4 intermediate revisions by 2 users not shown) | |||
Line 33: | Line 33: | ||
# Click OK, then click Connect. | # Click OK, then click Connect. | ||
*WS_FTP Pro ( | *WS_FTP Pro (12.4) | ||
# | # Connections | ||
# | # Site Manager | ||
# | # Right click the site to display hidden files, click Properties | ||
# Startup tab | # Startup tab | ||
# In Remote Filter Mask box enter -a | # In Remote Filter Mask box enter -a | ||
Line 160: | Line 160: | ||
You can put in any extension you want instead of .php5. Note that putting .html or .htm will force the server to process *all* HTML files as PHP, which is significantly slower than the normal way of processing these files. | You can put in any extension you want instead of .php5. Note that putting .html or .htm will force the server to process *all* HTML files as PHP, which is significantly slower than the normal way of processing these files. | ||
==== Redirect HTTP to HTTPS ==== | |||
<pre> | |||
# Redirects http:// traffic to https:// | |||
# Bravenet uses a reverse proxy, hence X-Forwarded-Proto | |||
RewriteCond %{HTTP:X-Forwarded-Proto} !https | |||
RewriteRule ^ https://%{HTTP_HOST}%{REQUEST_URI} [L,R=301] | |||
</pre> | |||
====Wordpress root folder redirection==== | |||
When installing Wordpress with our [[Installing Software | Software Installer]], it's not possible to install to your root folder, so you will need to choose a folder. If you want your installation to load when visiting a root address (ie: subdomain.yourdomain.com instead of it's installed path), you will need to configure your.htaccess file as follows: | |||
<pre> | |||
# BEGIN WordPress redirect | # BEGIN WordPress redirect | ||
<IfModule mod_rewrite.c> | <IfModule mod_rewrite.c> | ||
Line 173: | Line 184: | ||
</IfModule> | </IfModule> | ||
# END WordPress redirect | # END WordPress redirect | ||
</pre> | |||
Assuming your Wordpress installation path is yourdomain.com/wordpress - this code in the .htaccess file in your root directory will work to redirect your domain address to your wordpress installation folder, while maintaining yourdomain.com as the address in your browser's address bar. | Assuming your Wordpress installation path is yourdomain.com/wordpress - this code in the .htaccess file in your root directory will work to redirect your domain address to your wordpress installation folder, while maintaining yourdomain.com as the address in your browser's address bar. | ||
Ensure that you CTRL-F5 force refresh the page. If the changes are still not visible, clear your browser's [[Old pages still appear after making changes | cache of temporary files]]. | |||
===Resources=== | ===Resources=== |
Latest revision as of 15:48, 28 March 2019
- This feature is only available for Professional hosting accounts.
- This feature is recommended for users of intermediate to advanced levels
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 with an .htaccess file 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 to undo your changes.
- .htaccess files are very picky about what you put in them so please be careful to use exact syntax.
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 (12.4)
- Connections
- Site Manager
- Right click the site to display hidden files, click Properties
- 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 or edit your .htaccess files.
Using htaccess To...
Add a password to your site
To protect your full folder, you will need two files:
- The .htaccess file - this is placed inside the folder you want to protect
- The .htpasswd file - this should be placed in a folder on your site where only you have access to edit it
The server path you need to add to the beginning of your AuthUserFile path is located within your Bravenet account. The AuthUserFile path should point to your password file. To get the path, login to your Bravenet.com account, click on Websites, click on your URL, and then scroll down to the Storage Path. In this example, the storage path is /misc/12/345/678/901/2/user/web/securearea.mysite.org/
You would add the following to your .htaccess file:
AuthUserFile /misc/12/345/678/901/2/user/web/securearea.mysite.org/.htpasswd AuthName "Private Area" AuthType Basic require valid-user
Your .htpasswd file would look something like this:
bravenet:B3nlQW12jcynE admin:cGyUX9QugYMgE
The passwords stored in the .htpasswd file are encrypted - if you want admin's password to be password, you would first have to run password through a password generator, such as you can find here, getting cGyUX9QugYMgE. This would be be the password you would place in the .htpasswd file. Now, when visiting securearea.mysite.org, you would be prompted for a username and password. admin with the password of password would give you access to the site.
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]
Use custom error pages
If you would like to have custom error pages, you can add the following to your .htaccess file:
ErrorDocument 404 404.php ErrorDocument 403 403.php ErrorDocument 500 500.php ErrorDocument 401 401.php
Now if someone visits, for example, www.yoursite.com/this_page_does_not_exist they will get served 404.php as an error page instead of the default 404_not_found.html page.
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. People who are blocked from your site will be shown the 403 error page (by default 403_forbidden.html)
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
Enable PHP processing in non-.php files
If you have a file with PHP code in it that's doesn't have the filename ending in .php (say, example_file.php5) you can force the web servers to treat it as PHP anyways:
AddType application/x-httpd-php .php5
You can put in any extension you want instead of .php5. Note that putting .html or .htm will force the server to process *all* HTML files as PHP, which is significantly slower than the normal way of processing these files.
Redirect HTTP to HTTPS
# Redirects http:// traffic to https:// # Bravenet uses a reverse proxy, hence X-Forwarded-Proto RewriteCond %{HTTP:X-Forwarded-Proto} !https RewriteRule ^ https://%{HTTP_HOST}%{REQUEST_URI} [L,R=301]
Wordpress root folder redirection
When installing Wordpress with our Software Installer, it's not possible to install to your root folder, so you will need to choose a folder. If you want your installation to load when visiting a root address (ie: subdomain.yourdomain.com instead of it's installed path), you will need to configure your.htaccess file as follows:
# BEGIN WordPress redirect <IfModule mod_rewrite.c> RewriteEngine On RewriteRule %{REQUEST_URI} !^/wordpress/ RewriteCond %{REQUEST_FILENAME} !-f RewriteCond %{REQUEST_FILENAME} !-d RewriteRule ^(.*)$ /wordpress/$1 RewriteRule ^(/)?$ /wordpress/index.php [L] </IfModule> # END WordPress redirect
Assuming your Wordpress installation path is yourdomain.com/wordpress - this code in the .htaccess file in your root directory will work to redirect your domain address to your wordpress installation folder, while maintaining yourdomain.com as the address in your browser's address bar.
Ensure that you CTRL-F5 force refresh the page. If the changes are still not visible, clear your browser's cache of temporary files.
Resources
- 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.