Apache中.htaccess文件功能

softyun3年前服务器57

作为用户,所能使用的命令受到限制。管理员可以通过Apache 的AllowOverride指令来设置.子目录中的指令会覆盖更高级目录或者主服务器配置文件中的指令。


一、错误文档的定位

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

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

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

500 Internal Server Error

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

ErrorDocument 404 /errors/notfound
ErrorDocument 500 /errors/internalerror
一条指令一行。


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

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

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

ErrorDocument 401 "<body bgcolor=#ffffff> 你没有权限访问该页面! </body>"

二、文档访问的密码保护要利用.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.21.112.43
deny from 219.146.95
allow from all

注: 第二行拒绝某个IP,第三行拒绝某个IP段,也就是219.146.95.0~219.146.95.255 想要拒绝所有人?用deny from all好了。不止用IP,也可以用域名来设定。

四、保护.htaccess文档

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

<Files .htaccess>
order allow,deny
deny from all
</Files>

五、URL转向

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

Redirect /旧目录/旧文档名 新文档的地址
或者整个目录的转向:
Redirect 旧目录 新目录
改变缺省的首页文件

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

DirectoryIndex 新的缺省文件名

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

例如:

DirectoryIndex filename index.cgi index.pl default.htm

Contact_us Email:ztuteng@gmail or QQ:277024877

免责声明:本文内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。请核实广告和内容真实性,谨慎使用。

相关文章

网站服务器与APP服务器之间有何区别

接触过网站的朋友都知道,在南昌网站建设中,建站除了要买域名,写程序等方面的东西外,服务器也是不可缺少的。而细心的朋友便会发现,其实APP开发跟建站是一样需要服务器的。说到这里,相信就有很多朋友有这样的...

Win下解决phpStudy MySQL启动失败

报错Apache\Nginx服务正常启动了,但是MySQL却一直启动失败。解决流程查看端口是否被占用打开系统自带的资源管理器,查看监听端口3306是不是被占用,下图中3306端口被mysqld.exe...

韩国高防服务器到底需要您为它出多少力,韩国高防服务器有哪些性能优势

1.韩国高防服务器简介韩国高防服务器是一种具备高防能力的网络服务器,在拥有最技术支持的同时,还具备极强的抗攻击能力,可有效保障用户的数据安全和网络稳定运行。该服务器一般应用于各种大型网站、金融平台、游...

有哪些方法可以提高网站服务器的速度?

网站服务器是当今计算能力的重要,但是有很多应接不暇的方法可以选择网站服务器来载重工作上负载。尽管可以用一样的虚拟技术和集群服务器化的具备管理能力的白盒系统填充云数据中心,随着许多的公司云空间部署工作负...

域名注册公司的功能和作用是什么,什么是域名注册公司

域名注册公司,是指一种提供域名注册服务的企业。域名是网站访问的地址,而域名注册服务就是通过这个地址实现网站的访问和管理。域名注册公司可以为企业和个人提供注册、续费和转让域名的服务。域名注册公司的主要功...

云服务器无法安装宝塔面板及软件解决方案

最近遇到阿里云的服务器无法安装宝塔,或者安装完宝塔之后PHP、Nginx、mysql等软件无法安装现象,其实以前也有遇到一些其他厂商服务器,或者海外服务器无法安装的情况,下面给出一个综合解决方案。本教...