WebjxCom提示:.htaccess文件(HypertextAccessfile)是ApacheWeb
服务器的一个非常强大的配置文件
,对于这个文件
,Apache有一堆参数可以让你配置出几乎随心所欲的功能
。.htaccess配置文件坚持了Unix的一个文化——使用一个ASCII的纯文本文件来配置你的网站的访问策略
。 .htaccess文件(HypertextAccessfile)是ApacheWeb
服务器的一个非常强大的配置文件,对于这个文件,Apache有一堆参数可以让你配置出几乎随心所欲的功能。.htaccess配置文件坚持了Unix的一个文化——使用一个ASCII的纯文本文件来配置你的网站的访问策略。
这篇文章包括了16个非常有用的小技巧。另外,因为.htaccess是一个相当强大的配置文件,所以,一个轻微的语法错误会造成你整个网站的故障,所以,在你修改或是替换原有的文件时,一定要备份旧的文件,以便出现问题的时候可以方便的恢复。
1.使用.htaccess创建自定义的出错页面。对于LinuxApache来说这是一项极其简单的事情。使用下面的.htaccess语法你可以轻松的完成这一功能。(把.htaccess放在你的网站根目录下)
ErrorDocument401/error/401.php
ErrorDocument403/error/403.php
ErrorDocument404/error/404.php
ErrorDocument500/error/500.php
2.设置网站的时区
SetEnvTZAmerica/Houston
3.阻止IP列表
有些时候,你需要以IP地址的方式阻止一些访问。无论是对于一个IP地址还是一个网段,这都是一件非常简单的事情,如下所示:
allowfromall
denyfrom145.186.14.122
denyfrom124.15
Apache对于被拒绝的IP会返回403错误。
4.把一些老的链接转到新的链接上——
搜索引擎优化SEO
Redirect301/d/file.htmlhttp://www.htaccesselite.com/r/file.html
5.为服务器管理员设置电子邮件。
ServerSignatureEMail
SetEnvSERVER_ADMINdefault@domain.com 6.使用.htaccess访止盗链。如果你网站上的一个图片被别的N多的网站引用了,那么,这很有可能会导致你服务器的性能下降,使用下面的代码可以保护某些热门的链接不被过多的引用。
Options+FollowSymlinks
#ProtectHotlinking
RewriteEngineOn
RewriteCond%{HTTP_REFERER}!^$
RewriteCond%{HTTP_REFERER}!^http://(
www.)?domainname.com/[nc]
RewriteRule.*.(gif|jpg|png)$http://domainname.com/img/hotlink_f_o.png[nc]
7.阻止UserAgent的所有请求
##.htaccessCode::BEGIN
##BlockBadBotsbyuser-Agent
SetEnvIfNoCaseuser-Agent^FrontPage[NC,OR]
SetEnvIfNoCaseuser-Agent^Java.*[NC,OR]
SetEnvIfNoCaseuser-Agent^Microsoft.URL[NC,OR]
SetEnvIfNoCaseuser-Agent^MSFrontPage[NC,OR]
SetEnvIfNoCaseuser-Agent^Offline.Explorer[NC,OR]
SetEnvIfNoCaseuser-Agent^[Ww]eb[Bb]andit[NC,OR]
SetEnvIfNoCaseuser-Agent^Zeus[NC]
OrderAllow,Deny
Allowfromall
Denyfromenv=bad_bot
##.htaccessCode::END
8.把某些特殊的IP地址的请求重定向到别的站点
ErrorDocument403http://www.youdomain.com
Orderdeny,allow
Denyfromall
Allowfrom124.34.48.165
Allowfrom102.54.68.123
9.直接找开文件而不是下载–通常,我们打开网上文件的时候总是会出现一个对话框问我们是下载还是直接打开,使用下面的设置就不会出现这个问题了,直接打开。
AddTypeapplication/octet-stream.pdf
AddTypeapplication/octet-stream.zip
AddTypeapplication/octet-stream.mov
10.修改文件类型–下面的示例可以让任何的文件都成为
PHP那么被服务器解释。比如:myphp,
cgi,phtml等。
ForceTypeapplication/x-httpd-php
SetHandlerapplication/x-httpd-php
11.阻止存取.htaccess文件
#securehtaccessfile
orderallow,deny
denyfromall
12.保护服务器上的文件被存取
#preventaccessofacertainfileorderallow,deny
denyfromall
13.阻止目录浏览
#disabledirectorybrowsing
OptionsAll-Indexes
14.设置默认主页
#servealternatedefaultindexpage
DirectoryIndexabout.html
15.口令认证–你可以创建一个文件用于认证。下面是一个示例:
#toprotectafile
AuthTypeBasic
AuthName“Prompt”
AuthUserFile/home/path/.htpasswd
Requirevalid-user
#password-protectadirectory
resides
AuthTypebasic
AuthName“Thisdirectoryisprotected”
AuthUserFile/home/path/.htpasswd
AuthGroupFile/dev/null
Requirevalid-user
16.把老的域名转像新的域名
#redirectfromolddomaintonewdomain
RewriteEngineOn
RewriteRule^(.*)$http://www.yourdomain.com/$1[R=301,L]