程序员不知道的16条.htaccess文件设置技巧

文章由脚本100提供,希望本文所述对大家 学习php有所帮助,也希望大家继续关注脚本100

转载原文地址:http://www.jb100.net/html/content-22-741-1.html


.htaccess 文件 (Hypertext Access file) 是Apache Web服务器的一个非常强大的配置文件,对于这个文件,Apache有一堆参数可以让你配置出几乎随心所欲的功能。.htaccess 配置文件坚持了Unix的一个文化——使用一个ASCII 的纯文本文件来配置你的网站的访问策略。

这篇文章包括了16个非常有用的小技巧。另外,因为.htaccess 是一个相当强大的配置文件,所以,一个轻微的语法错误会造成你整个网站的故障,所以,在你修改或是替换原有的文件时,一定要备份旧的文件,以便出现问题的时候可以方便的恢复。

1. 使用.htaccess 创建自定义的出错页面。对于Linux Apache来说这是一项极其简单的事情。使用下面的.htaccess语法你可以轻松的完成这一功能。(把.htaccess放在你的网站根目录下)

  1. ErrorDocument 401 /error/401.php 

  2. ErrorDocument 403 /error/403.php 

  3. ErrorDocument 404 /error/404.php 

  4. ErrorDocument 500 /error/500.php


2. 设置网站的时区

  1. SetEnv TZ America/Houston 


3. 阻止IP列表
有些时候,你需要以IP地址的方式阻止一些访问。无论是对于一个IP地址还是一个网段,这都是一件非常简单的事情,如下所示:

  1. allow from all 

  2. deny from 145.186.14.122 

  3. deny from 124.15 



Apache对于被拒绝的IP会返回403错误。

4. 把一些老的链接转到新的链接上——搜索引擎优化SEO

  1. Redirect 301 /d/file.htmlhttp://www.htaccesselite.com/r/file.html


5. 为服务器管理员设置电子邮件。

  1. ServerSignature EMail 

  2. SetEnv SERVER_ADMINdefault@domain.com 


6. 使用.htaccess 访止盗链。如果你网站上的一个图片被别的N多的网站引用了,那么,这很有可能会导致你服务器的性能下降,使用下面的代码可以保护某些热门的链接不被过多的引用。

  1. Options +FollowSymlinks 

  2. # Protect Hotlinking 

  3. RewriteEngine On 

  4. RewriteCond %{HTTP_REFERER} !^$ 

  5. RewriteCond %{HTTP_REFERER} !^http://(www.)?domainname.com/[nc] 

  6. RewriteRule .*.(gif|jpg|png)$http://domainname.com/img/hotlink_f_o.png[nc] 



7. 阻止 User Agent 的所有请求

  1. ## .htaccess Code :: BEGIN 

  2. ## Block Bad Bots by user-Agent 

  3. SetEnvIfNoCase user-Agent ^FrontPage [NC,OR] 

  4. SetEnvIfNoCase user-Agent ^Java.* [NC,OR] 

  5. SetEnvIfNoCase user-Agent ^Microsoft.URL [NC,OR] 

  6. SetEnvIfNoCase user-Agent ^MSFrontPage [NC,OR] 

  7. SetEnvIfNoCase user-Agent ^Offline.Explorer [NC,OR] 

  8. SetEnvIfNoCase user-Agent ^[Ww]eb[Bb]andit [NC,OR] 

  9. SetEnvIfNoCase user-Agent ^Zeus [NC] 

  10.  

  11. Order Allow,Deny 

  12. Allow from all 

  13. Deny from env=bad_bot 

  14.  

  15. ## .htaccess Code :: END 



8. 把某些特殊的IP地址的请求重定向到别的站点

  1. ErrorDocument 403http://www.youdomain.com 

  2. Order deny,allow 

  3. Deny from all 

  4. Allow from 124.34.48.165 

  5. Allow from 102.54.68.123 



9. 直接找开文件而不是下载– 通常,我们打开网上文件的时候总是会出现一个对话框问我们是下载还是直接打开,使用下面的设置就不会出现这个问题了,直接打开。

  1. AddType application/octet-stream .pdf 

  2. AddType application/octet-stream .zip 

  3. AddType application/octet-stream .mov 



10. 修改文件类型– 下面的示例可以让任何的文件都成为PHP那么被服务器解释。比如:myphp, cgi,phtml等。

  1. ForceType application/x-httpd-php 

  2. SetHandler application/x-httpd-php 


11. 阻止存取.htaccess 文件

  1. # secure htaccess file 

  2.  

  3.  order allow,deny 

  4.  deny from all 


12. 保护服务器上的文件被存取

  1. # prevent access of a certain fileorder allow,deny 

  2.  deny from all 


13. 阻止目录浏览

  1. # disable directory browsing 

  2. Options All -Indexes 



14. 设置默认主页

  1. # serve alternate default index page 

  2. DirectoryIndex about.html 



15. 口令认证– 你可以创建一个文件用于认证。下面是一个示例:

  1. # to protect a file 

  2.  

  3. AuthType Basic 

  4. AuthName “Prompt” 

  5. AuthUserFile /home/path/.htpasswd 

  6. Require valid-user 

  7.  

  8. # password-protect a directory 

  9. resides 

  10. AuthType basic 

  11. AuthName “This directory is protected” 

  12. AuthUserFile /home/path/.htpasswd 

  13. AuthGroupFile /dev/null 

  14. Require valid-user 



16. 把老的域名转像新的域名

  1. # redirect from old domain to new domain 

  2. RewriteEngine On 

  3. RewriteRule ^(.*)$http://www.yourdomain.com/$1[R=301,L] 

文章由脚本100提供,希望本文所述对大家 学习php有所帮助,也希望大家继续关注脚本100

转载原文地址:http://www.jb100.net/html/content-22-741-1.html


转载于:https://my.oschina.net/u/2285640/blog/353045

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值