主机头

标题: .htaccess应用技术总结及代码收集 [打印本页]

作者: admin    时间: 2013-5-14 20:54
标题: .htaccess应用技术总结及代码收集
.htaccess应用技巧总结,这是转载自张自然先森的博客的文章。



整理了我知道的全部.htaccess应用技巧,如果你还知道更多,可以帮我补充!!
.htaccess简介:
.htaccess 文件 (Hypertext Access file) 是Apache Web服务器的一个非常强大的配置文件,对于这个文件,Apache有一堆参数可以让你配置出几乎随心所欲的功能。.htaccess 配置文件坚持了Unix的一个文化——使用一个ASCII 的纯文本文件来配置你的网站的访问策略。
友情提醒:
因为.htaccess 是一个相当强大的配置文件,所以,一个轻微的语法错误会造成你整个网站的故障,所以,在你修改或是替换原有的文件时,一定要备份旧的文件,以便出现问题的时候可以方便的恢复。

利用.htaccess实现一个空间方多个网站
比如说我要将zj bk  .cn这个域名绑定到zjbk这个目录,代码应该这么写:第三第四行代码无限复制,别的不多说,自个做实验吧!
  1. <IfModule mod_rewrite.c>

  2. RewriteEngine on

  3. RewriteCond %{HTTP_HOST} ^(www.)?www.zhujitou.com$ [NC]

  4. RewriteRule ^(.*)$ /blog/$1 [L]

  5. </IfModule>
复制代码
然后在相应的子目录新建.htaccess放置如下代码
  1. <IfModule mod_rewrite.c>

  2. RewriteEngine on

  3. RewriteBase /blog/

  4. </IfModule>
复制代码
把一些老的链接301重定向到新的链接上
  1. Redirect 301 /htaccess.htm http://www.zhujitou.com/htaccessjiqiao
复制代码
把老的域名转向新的域名
  1. # redirect from old domain to new domain

  2. RewriteEngine On

  3. RewriteRule ^(.*)$ http://www.yourdomain.com/$1 [R=301,L]
复制代码
将不带WWW的域名301重定向到带WWW的域名下
  1. Options +FollowSymLinks

  2. RewriteEngine on

  3. RewriteCond %{HTTP_HOST} ^amznz.com [NC]

  4. RewriteRule ^(.*)$ http://www.amznz.com/$1 [L,R=301]
复制代码
不如我在zhangziran.com这个站点添加了这个htaccess规则
使用效果:
  1. <p>访问 http://www.zhujitou.com  转为  http://www.zhujitou.com</p>
  2. <p>访问 http://www.zhujitou.com/bokexinde

  3. 转为  http://www.zhujitou.com/bokexinde</p>
复制代码
重定向到新域名(多域名301重定向)
  1. Options +FollowSymLinks

  2. RewriteEngine on

  3. RewriteRule ^(.*)$ http://www.amznz.com/$1 [L,R=301]
复制代码
比如我在vpse.net这个站点添加了这个htaccess规则
使用效果:
访问 http://vpse.net  转为  http://www.zhujitou.com
访问 http://www.vpse.net  转为  http://www.zhujitou.com
访问 http://vpse.net/bokexinde
转为  http://www.zhujitou.com/bokexinde
访问 http://www.vpse.net/bokexinde
转为  http://www.zhujitou.com/bokexinde
使用.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]
复制代码
设置网站的时区
  1. SetEnv TZ America/Houston
复制代码
保护服务器上的文件被存取
  1. # prevent access of a certain file order allow,deny

  2. deny from all
复制代码
阻止目录浏览
  1. # disable directory browsing

  2. Options All -Indexes
复制代码
设置默认主页
  1. # serve alternate default index page

  2. DirectoryIndex about.html
复制代码
阻止IP列表
有些时候,你需要以IP地址的方式阻止一些访问。无论是对于一个IP地址还是一个网段,这都是一件非常简单的事情,如下所示:
  1. allow from all

  2. deny from 145.186.14.122

  3. deny from 124.15
复制代码
Apache对于被拒绝的IP会返回403错误。
使用.htaccess 创建自定义的出错页面。对于Linux Apache来说这是一项极其简单的事情。使用下面的.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
复制代码
为服务器管理员设置电子邮件。
  1. ServerSignature EMail

  2. SetEnv SERVER_ADMIN [email protected]
复制代码
阻止 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. Order Allow,Deny

  11. Allow from all

  12. Deny from env=bad_bot

  13. ## .htaccess Code :: END
复制代码
把某些特殊的IP地址的请求重定向到别的站点
  1. ErrorDocument 403 http://www.youdomain.com

  2. Order deny,allow

  3. Deny from all

  4. Allow from ip

  5. Allow from ip
复制代码
直接找开文件而不是下载 – 通常,我们打开网上文件的时候总是会出现一个对话框问我们是下载还是直接打开,使用下面的设置就不会出现这个问题了,直接打开。
  1. AddType application/octet-stream .pdf

  2. AddType application/octet-stream .zip

  3. AddType application/octet-stream .mov
复制代码
修改文件类型 – 下面的示例可以让任何的文件都成为PHP那么被服务器解释。比如:myphp, cgi,phtml等。
  1. ForceType application/x-httpd-php

  2. SetHandler application/x-httpd-php
复制代码
阻止存取.htaccess 文件
  1. # secure htaccess file

  2. order allow,deny

  3. deny from all
复制代码
口令认证 – 你可以创建一个文件用于认证。下面是一个示例:
  1. <blockquote><p># to protect a file

  2. AuthType Basic

  3. AuthName “Prompt”

  4. AuthUserFile /home/path/.htpasswd

  5. Require valid-user

  6. # password-protect a directory

  7. resides

  8. AuthType basic

  9. AuthName “This directory is protected”

  10. AuthUserFile /home/path/.htpasswd

  11. AuthGroupFile /dev/null

  12. Require valid-user</p>
复制代码












欢迎光临 主机头 (http://zhujitou.com/) Powered by Discuz! X2.5