Categories


Tags


htaccess文件使用大全

Apache系统中的.htaccess文件(或者”分布式配置文件”提供了针对目录改变配置的方法, 即,在一个特定的文档目录中放置一个包含一个或多个指令的文件, 以作用于此目录及其所有子目录。作为用户,所能使用的命令受到限制。管理员可以通过Apache的AllowOverride指令来设置。

子目录中的指令会覆盖更高级目录或者主服务器配置文件中的指令。

.htaccess必须以ASCII模式上传,最好将其权限设置为644。

错误文档的定位

常用的客户端请求错误返回代码:

401 Authorization Required

403 Forbidden

404 Not Found

405 Method Not Allowed

408 Request Timed Out

411 Content Length Required

412 Precondition Failed

413 Request Entity Too Long

414 Request URI Too Long

415 Unsupported Media Type

常见的服务器错误返回代码:

500 Internal Server Error

用户可以利用.htaccess指定自己事先制作好的错误提醒页面。一般情况下,人们可以专门设立一个目录,例如errors放置这些页面。然后再.htaccess中,加入如下的指令:

ErrorDocument 404 /errors/notfound.html

ErrorDocument 500 /errors/internalerror.html

一条指令一行。上述第一条指令的意思是对于404,也就是没有找到所需要的文档的时候得显示页面为/errors目录下的notfound.html页面。不难看出语法格式为:

ErrorDocument 错误代码 /目录名/文件名.扩展名

如果所需要提示的信息很少的话,不必专门制作页面,直接在指令中使用HTML号了,例如下面这个例子:

ErrorDocument 401 “你没有权限访问该页面,请放弃!”

文档访问的密码保护

要利用.htaccess对某个目录下的文档设定访问用户和对应的密码,首先要做的是生成一个.htpasswd的文本文档,例如:

zheng:y4E7Ep8e7EYV

这里密码经过加密,用户可以自己找些工具将密码加密成.htaccess支持的编码。该文档最好不要放在www目录下,建议放在www根目录文档之外,这样更为安全些。

有了授权用户文档,可以在.htaccess中加入如下指令了:

AuthUserFile .htpasswd的服务器目录

AuthGroupFile /dev/null (需要授权访问的目录)

AuthName EnterPassword

AuthType Basic (授权类型)

require user wsabstract (允许访问的用户,如果希望表中所有用户都允许,可以使用 require valid-user)

注,括号部分为学习时候自己添加的注释

拒绝来自某个IP的访问

如果我不想某个政府部门访问到我的站点的内容,那可以通过.htaccess中加入该部门的IP而将它们拒绝在外。

例如:

order allow,deny

deny from 210.10.56.32

deny from 219.5.45.

allow from all

第二行拒绝某个IP,第三行拒绝某个IP段,也就是219.5.45.0~219.2.45.255

想要拒绝所有人?用deny from all好了。不止用IP,也可以用域名来设定。

保护.htaccess文档

在使用.htaccess来设置目录的密码保护时,它包含了密码文件的路径。从安全考虑,有必要把.htaccess也保护起来,不让别人看到其中的内容。虽然可以用其他方式做到这点,比如文档的权限。不过,.htaccess本身也能做到,只需加入如下的指令:

order allow,deny

deny from all

URL转向

我们可能对网站进行重新规划,将文档进行了迁移,或者更改了目录。这时候,来自搜索引擎或者其他网站链接过来的访问就可能出错。这种情况下,可以通过如下指令来完成旧的URL自动转向到新的地址:

Redirect /旧目录/旧文档名 新文档的地址

或者整个目录的转向:

Redirect 旧目录 新目录

改变缺省的首页文件

一般情况下缺省的首页文件名有default、index等。不过,有些时候目录中没有缺省文件,而是某个特定的文件名,比如在pmwiki中是pmwiki.php。这种情况下,要用户记住文件名来访问很麻烦。在.htaccess中可以轻易的设置新的缺省文件名:

DirectoryIndex 新的缺省文件名

也可以列出多个,顺序表明它们之间的优先级别,例如:

DirectoryIndex filename.html index.cgi index.pl default.htm

防止盗链

如果不喜欢别人在他们的网页上连接自己的图片、文档的话,也可以通过htaccess的指令来做到。

所需要的指令如下:

RewriteEngine on

RewriteCond %{ HTTP_REFERER } !^$

RewriteCond %{ HTTP_REFERER } !^http://(www.)?mydomain.com/.*$ [NC]

RewriteRule .(gif&line;jpg)$ - [F]

如果觉得让别人的页面开个天窗不好看,那可以用一张图片来代替:

RewriteEngine on

RewriteCond %{ HTTP_REFERER } !^$

RewriteCond %{ HTTP_REFERER } !^http://(www.)?mydomain.com/.*$ [NC]

RewriteRule .(gif&line;jpg)$ http://www.mydomain.com/替代图片文件名 [R,L]

来源:月光博客


Public @ 2010-05-06 16:14:35

决定网站访问速度的几个因素以及优化方向

影响网站访问速度的几个因素包括: 1. 服务器响应时间:服务器的处理速度和响应时间会直接影响网站的访问速度。优化方向可以包括优化服务器硬件、软件和网络环境,提高响应速度。 2. 网络延迟:网络延迟指的是数据从用户设备到服务器之间传输的时间。优化方向可以包括选择更好的网络服务提供商、使用内容分发网络(CDN)等,加速数据传输。 3. 页面大小和内容:网站中包含的大量图片、视频、脚本和样式表等文

Public @ 2023-06-30 11:50:19

闲置域名怎么用

闲置域名也就是你注册了但没用上的域名,有人是为了保护公司产品域名、有人是为了抢注域名、有人是决定这个域名不错。加上现在域名价格非常便宜,域名资源紧缺,于是乎,无论有钱没钱的,都要人手多个域名,这样闲置域名就多了,垃圾站就多了。为了不让闲置的域名成一种资源浪费,卢松松大致总结了以下几个常见的闲置域名的用法。1:301重定向到主域名大多数公司和个人网站会同时注册.com/.cn/.net等域名,把多个

Public @ 2014-05-20 16:00:29

使用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

更多您感兴趣的搜索

0.462821s