Categories


Tags


五个htaccess文件的常用技巧

说起.htaccess规则文件,很多朋友都不会陌生,特别是使用wordpress、discuz等php类开源产品的朋友,该文件的作用与windows主机下的httpd.ini文件稍有雷同之处,但.htaccess的作用要大得多,我的几个站点也都使用了.htaccess文件,今天就分享几个常用的技巧。

Htaccess 文件是Apache HTTP web服务器的纯文本配置文件。无需访问httpd.conf 文件,用户就可以设置目录选项。因此,要求你的服务器使用Apache,并且主机也支持htaccess文件(大多数主机都支持)。

1. 防止盗链

盗链 也叫内嵌链接,是指一个网站的链接直接导向另一个网站上的对象。这会给另一个网站造成带宽和流量的损失。对于提供大量图片的站点来说,这个问题就比较严重。 使用htaccess可以解决这个问题。

我们将按下面的步骤一步步操作

首先得打开Apache里的mod_rewrite,用于实现重新定向用户的请求。

下一步,用RewriteCond设置条件。这需要运用到两个参数TestString 和CondPattern.TestString是用来验证CondPattern的字符串(使用常规的表达)。.${HTTP_REFERER}是Apache提供的域名请求变量。为了保护代理服务器用户提交空白请求,这里允许用户发送空白HTTP请求。

接着,用同样的句法设置允许链接图片的URL.命令最后的[NC]标记,只是让重写引擎忽视它。你可以用相同的句法添加更多的域名。为了方便举例,我添加了我的个人域名。

最后,最后一行是重写规则,上面所有的条件都不满足的情况下使用。也要用到两个变量Pattern和Substitution,pattern用的是常规的表达匹配,substitution 是替换任何匹配用的。此时,申请需以jpg、png、 gif结尾。找到申请后,用空白来替代。通过标签来进一步说明要干什么, NC代表无符合的情况,F发送403禁止错误页面给用户,L告知重写引擎停止重写,因此其它规则都不再适用。

这种方法相当简单,我们的目的也就是告诉用户我们不想他们盗用我们的图片,那么干脆不发送403错误禁止页面直接把盗链请求转到一个图片。把最后一行的代码用下面的代码替换就可以。

#show an alternate image

RewriteRule \.(jpg|png|gif)$ http://demo.collegeaintcheap.com/envato/htaccess/hotlink/images/hotlink.jpeg [NC,R,L]

你可以把域名URL地址改为图像路径,不过需要以jpg、png、gif 结尾。要不然会重新运用规则给服务器造成死循环。我建议使用.jpeg来解决这个问题。这里R标记取代F代表发送一个转向。

2. 通过IP地址阻止用户

如果网站上出现大量的垃圾邮件,就可以通过IP地址来阻止用户。你可以在日志文件里找到他们的IP,只要把IP地址添加到htaccess文件就可以。

Order Deny,Allow

Deny from 24.121.202.23

# Deny from 0.0.0.0

在mod_access模块里用Order指令可以拒绝或允许指定IP访问。只要使用句法Deny from IP ADDRESS就可以禁止这些用户访问我们的目录。

3.ErrorDocument

所有专业性的网站都会使用自定义的错误页面。在Apache 里可以使用ErrorDocument指令来完成。自定义的错误页面要比默认的页面好很多。

ErrorDocument有两个参数error-code和document.上面的代码是最常见的HTTP错误提示代码:404未找到、403 禁止、500 服务器出错。你可以给你的错误文件提供完整的URL或相对路径。你也可以转向到一个PHP脚本上,用一个数据库记录错误或者发送邮件给你(虽然有点烦人)。这是用来控制web应用程序的一个非常好的方法。看看 Smashing Magazine的404 错误页面展示获得一些启发吧!

ErrorDocument 401 /error/401.html      //401错误转向到error/401.html 页面

ErrorDocument 403 /error/403.html

ErrorDocument 404 /error/404.html

ErrorDocument 500 /error/500.html

4.升级时转向

如果你的网站正在升级,你需要转向到另一个页面通知用户,以防止用户看到损坏页面或者加载过程出现的潜在安全漏洞问题。在页面对所有用户开放前,我们需要先允许指定IP访问来测试。所有这些都可以在htaccess 文件上实现。

我们还是使用mod_rewrite 不过是一种逆向思维。首先我们需要设定条件来排除升级的文档,否则服务器陷入循环。接着,测试用的IP不执行转向。最后用重写规则给用户发回一个升级页面。标签还是跟之前的一样,只不过定向到302状态,告诉浏览器该页面暂时迁移了并做相应的缓存。同样地在Smashing Magazine,里也有很多的网站维护页面。

5. 隐藏目录列表

出于安全考虑,限制目录列表的权限和Apache默认行为是有必要的。这一点也可以在htaccess文件上实现。防止访问者看到我们的目录列表。

Options -Indexes

这样,用户如果发送无索引的目录请求,就会显示 403禁止错误页面。

是任何版本的Apache Web服务器都是支持.htaccess的。笼统地说,.htaccess可以帮我们实现包括:文件夹密码保护、用户自动重定向、自定义错误页面、改变你的文件扩展名、封禁特定IP地址的用户、只允许特定IP地址的用户、禁止目录列表,以及使用其他文件作为index文件等一些功能。

英文原文:5 Fun and Practical Htaccess Solutions

来源:月光博客


Public @ 2017-04-16 16:14:34

域名续费及赎回说明

请仔细阅读西部数码业务续费通知规则,建议绑定微信接收续费通知,以避免因忘记续费带来的损失。一.域名续费说明当您注册了域名后,您可以在注册使用期内使用该域名,使用期为 1 -10年不等。如您希望继续使用域名,则需要在该域名注册到期前续费。如果域名到期前未续费,则可能失去该域名。域名续费可在管理中心直接操作。二.域名续费宽限期我司续费宽限期为0-30天不等,不同后缀的续费宽限期不同,用户应该在域名到期

Public @ 2022-11-23 15:59:53

域名实名认证通知

域名实名认证通知尊敬的用户:您好!根据新版《互联网域名管理办法》的要求,在国内注册和使用的域名,必须经过实名认证后才可使用,为了落实相关规定,配合国家主管部门的要求,现规定如下:1、 新注册5天内需要进行实名认证的后缀有.top/.com/.net/.cn/.xyz/.vip/.wang/.club,否则域名会被锁定或者禁止解析,该规定已经在实施中;2、 当上述后缀的域名发生过户和转移时,也要落实

Public @ 2009-10-31 15:45:25

使用htaccess绑定域名到子目录

绑定某个域名到子目录,适合于那种购买一个虚拟主机,又想利用子目录的方式建立多个网站的用户。首先得把域名绑定绑定了,把你需要的网站解析到指定的IP地址,其次是在网站管理面板里,为网站绑定域名,最后编辑配置.htaccess文件,就可以了。.htaccess文件内容RewriteEngine on# 把 williamlong.info 改为你要绑定的域名.RewriteCond %{HTTP_HOS

Public @ 2015-07-17 16:14:33

htaccess文件使用大全

.htaccess 是 Apache 服务器的配置文件,它允许站点管理员通过在网站根目录中创建 .htaccess 文件来控制网站的访问权限、URL 重写、自定义错误页面等。 以下是 .htaccess 文件的使用方法: 1. 防止目录浏览 Options -Indexes 2. 禁止IP访问 order deny,allow deny from 127.0.0.1 deny from

Public @ 2023-04-28 06:00:11

更多您感兴趣的搜索