Apache 中 .htaccess 文件设置技巧16则

.htaccess 文件 (Hypertext Access file) 是Apache Web服务器的一个非常强大的配置文件,对于这个文件,Apache有一堆参数可以让你配置出几乎随心所欲的功能。.htaccess 配置文件坚持了Unix的一个文化——使用一个ASCII 的纯文本文件来配置你的网站的访问策略。
这篇文章包括了16个非常有用的小技巧。另外,因为.htaccess 是一个相当强大的配置文件,所以,一个轻微的语法错误会造成你整个网站的故障,所以,在你修改或是替换原有的文件时,一定要备份旧的文件,以便出现问题的时候可以方便的恢复。
1. 使用.htaccess 创建自定义的出错页面。对于Linux Apache来说这是一项极其简单的事情。使用下面的.htaccess语法你可以轻松的完成这一功能。(把.htaccess放在你的网站根目录下)
 
                        ErrorDocument 401 /error/401.php 
ErrorDocument 403 /error/403.php 
ErrorDocument 404 /error/404.php 
ErrorDocument 500 /error/500.php              
2. 设置网站的时区
 
                        SetEnv TZ America/Houston             
3. 阻止IP列表
有些时候,你需要以IP地址的方式阻止一些访问。无论是对于一个IP地址还是一个网段,这都是一件非常简单的事情,如下所示:
 
                        allow from all 
deny from 145.186.14.122 
deny from 124.15             
Apache对于被拒绝的IP会返回403错误。
4. 把一些老的链接转到新的链接上——搜索引擎优化SEO
 
                        Redirect 301 /d/file.htmlhttp://www.htaccesselite.com/r/file.html

5. 为服务器管理员设置电子邮件。
 
                        ServerSignature EMail 
SetEnv [[email protected]]SERVER_ADMIN[email protected][/email]             
6. 使用.htaccess 访止盗链。如果你网站上的一个图片被别的N多的网站引用了,那么,这很有可能会导致你服务器的性能下降,使用下面的代码可以保护某些热门的链接不被过多的引用。
 
                        Options +FollowSymlinks 
# Protect Hotlinking 
RewriteEngine On 
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. 阻止 User Agent 的所有请求
 
                        ## .htaccess Code :: BEGIN 
## Block Bad Bots by user-Agent 
SetEnvIfNoCase user-Agent ^FrontPage [NC,OR] 
SetEnvIfNoCase user-Agent ^Java.* [NC,OR] 
SetEnvIfNoCase user-Agent ^Microsoft.URL [NC,OR] 
SetEnvIfNoCase user-Agent ^MSFrontPage [NC,OR] 
SetEnvIfNoCase user-Agent ^Offline.Explorer [NC,OR] 
SetEnvIfNoCase user-Agent ^[Ww]eb[Bb]andit [NC,OR] 
SetEnvIfNoCase user-Agent ^Zeus [NC]

Order Allow,Deny 
Allow from all 
Deny from env=bad_bot

## .htaccess Code :: END              
8. 把某些特殊的IP地址的请求重定向到别的站点
 
                        ErrorDocument 403http://www.youdomain.com 
Order deny,allow 
Deny from all 
Allow from 124.34.48.165 
Allow from 102.54.68.123             
9. 直接找开文件而不是下载– 通常,我们打开网上文件的时候总是会出现一个对话框问我们是下载还是直接打开,使用下面的设置就不会出现这个问题了,直接打开。
 
                        AddType application/octet-stream .pdf 
AddType application/octet-stream .zip 
AddType application/octet-stream .mov             
10. 修改文件类型– 下面的示例可以让任何的文件都成为PHP那么被服务器解释。比如:myphp, cgi,phtml等。
 
                        ForceType application/x-httpd-php 
SetHandler application/x-httpd-php             
11. 阻止存取.htaccess 文件
 
                        # secure htaccess file

order allow,deny 
deny from all              
12. 保护服务器上的文件被存取
 
                        # prevent access of a certain fileorder allow,deny 
deny from all              
13. 阻止目录浏览
 
                        # disable directory browsing 
Options All -Indexes             
14. 设置默认主页
 
                        # serve alternate default index page 
DirectoryIndex about.html             
15. 口令认证– 你可以创建一个文件用于认证。下面是一个示例:
 
                        # to protect a file

AuthType Basic 
AuthName “Prompt” 
AuthUserFile /home/path/.htpasswd 
Require valid-user

# password-protect a directory 
resides 
AuthType basic 
AuthName “This directory is protected” 
AuthUserFile /home/path/.htpasswd 
AuthGroupFile /dev/null 
Require valid-user              
16. 把老的域名转像新的域名
 
                        # redirect from old domain to new domain 
RewriteEngine On 
RewriteRule ^(.*)$http://www.yourdomain.com/$1[R=301,L]

时间: 2024-11-07 01:34:21

Apache 中 .htaccess 文件设置技巧16则的相关文章

Apache中.htaccess文件的作用和配置

00x01 What's .htaccess      htaccess文件是Apache服务器中的一个配置文件,它负责相关目录下的网页配置.通过htaccess文件,可以帮我们实现:网页301重定向.自定义404错误页面.改变文件扩展名.允许/阻止特定的用户或者目录的访问.禁止目录列表.配置默认文档等功能. 一般来说,htaccess文件需要放在网站的根目录下才能控制整个站点,并且在Linux系统中,需要把其权限设置为644以提高安全性.国内很多主机提供商都通过一定技术手段禁用了该文件,但是国

Apache环境利用.htaccess文件设置域名301跳转(不带www跳转到带www)

相信很多站长朋友都遇见过这样的问题,即带www的域名与不带www的域名同时都被收录,但域名权重情况差距很大.这问题主要是由于搜索引擎把这两个域名当做两个不同网站看待,导致一个域名被判定是镜像网站造成的.毫无疑问,不管是带www还是不带www,唯一域名能够给你的网站带来更多的好处.这样无论是用户还是搜索引擎,都会记住你网站的唯一域名,也不会造成搜索引擎的误判而导致惩罚.下面本文就来介绍一下Apache环境下利用.htaccess文件设置301跳转,强制用户或搜索引擎重定向到唯一域名. #301重定

.htaccess文件设置

1.为使.htaccess有效,需要先做httpd.conf设置 #打开改写模式Options FollowSymLinks AllowOverride All#打开重写模式,去掉这行注释LoadModule rewrite_module modules/mod_rewrite.so 2..htaccess文件设置: (1)错误文件定位: 常用的客户端哀求错误返回代码: (详见http://www.cnblogs.com/boystar/p/4661106.html) 格式:ErrorDocum

WordPress中.htaccess的使用技巧

有些用户可能还不知道.htaccess文件是什么,所以我们首先来说明一下htaccess的作用.在wordpress的根目录下,你会看到一 个名为.htaccess的文件,它可以是由系统创建.也可以是用户自己编辑而成的.它是Apache服务器中的一个配置文件,它负责相关目录下的网页配 置,对wordpress中实现永久链接(Permalink)至关重要.同时利用它,我们也可以实现:网页301重定向.自定义404错误页面.改变文 件扩展名.允许/阻止特定的用户或者目录的访问.禁止目录列表.配置默认

ssh框架中.xml文件小技巧分离xml

struts.xml文件 struts.xml文件里的action可以分离出来,如: <!-- 预警信息监测 --> <include file="config/struts/warningInformAtion-struts.xml"></include> 注: include是放在</struts>标签的前面 在src下面新建 package 名为:config.struts,再新建xml文件为warningInformAtion-s

PHP框架中.htaccess文件作用

1..htaccess文件使用前提 .htaccess的主要作用就是实现url改写,也就是当浏览器通过url访问到服务器某个文件夹时,作为主人,我们可以来接待这个url,具体地怎样接待它,就是此文件的作用.所有的访问都是通过URL实现,所以.htaccess的作用非同小可.正因为此,所以一般地网站通过设置.htaccess,通过一个十分友好的url吸引用户进来,然后用.htaccess把用户带到需要访问的位置. 要想使用这个强大功能,就得开启apache里面的重写模块. 前面的文章中曾经讲到过w

取消apache对.htaccess文件的限制

问题 当访问一个站点的时候,报告“500 Internal Server Error”,查看/var/log/httpd/error_log,报告“/www/users/test.com/.htaccess: Options not allowed here”,或者报告“ErrorDocument not allowed here”等信息. 解决方案 这是由于客户在自己的网站的目录内放置了.htaccess文件.使用.htaccess文件,可以对网站目录的一些特性做子定义,如调整默认首页顺序.设

mac下为Apache 创建 .htaccess文件

在设置固定链接时会提示如下的问题: 若您的 .htaccess 文件可写,我们可以自动修改它.但似乎它不可写,因此我们在下方列出了您 .htaccess 文件中应该加入的URL 重写规则.点击下方的文本区域,按 CTRL+ a 来全选. 需要将下面的代码写入 .htaccess文件 <IfModule mod_rewrite.c> RewriteEngine On RewriteBase /wordpress/ RewriteRule ^index\.php$ - [L] RewriteCon

浅析网站结构优化中导航系统的设置技巧

站长们,你们对于网站结构优化中导航系统的设置知多少呢?导航系统的设置的好坏对于网站结构的优化有着相当大的影响.咱们的导航做的目标越清晰,越符合用户的体验度.人性化一点来说,网站导航就跟汽车导航的作用差不多,指明目标,所以我们要从两个方面考虑如何导航系统. 从用户的角度来看,第一点用户可能会从任何一个内页进入到咱们的网站,导航系统要做的就是随时清除的让用户知道自己在网站的哪个位置.因为点开多个网站的内页后,用户自己也已经晕了,不知道自己是怎么点进这个页面的.所以,我们在设计的时候最好统一页面的风格