.htaccess重定向和url重写详细介绍

softyun3年前云服务器17

什么是htaccess

概述来说,htaccess文件是Apache服务器中的一个配置文件,它负责相关目录下的网页配置。通过htaccess文件,可以帮我们实现:网页301重定向、自定义404错误页面、改变文件扩展名、允许/阻止特定的用户或者目录的访问、禁止目录列表、配置默认文档等功能。

一个简单的重定向

复制代码 代码如下:

Redirect 301 ^old$ localhost/new


这是设置一个http状态码为301(永久移动)并把所有访问old转向到new。使用了正则表达式来匹配访问的页面,后面的url必须是完整路径。

Url重写

复制代码 代码如下:


RewriteEngine on
RewriteRule ^old$ new


第一行打开重写引擎
第二行是重写规则。这样用户访问old时实际却是访问的new,而且用户对此好吧知情。因为地址栏里依旧显示是old。

为了在地址栏显示新的访问地址,我们可以加个f标志在rewriterule语句里。

复制代码 代码如下:


RewriteRule ^old$ hostname/new [r=301]


下面是把带查询参数的url重写成对搜索引擎友好的url

复制代码 代码如下:


RewriteRule ^products/([^/]+)/([^/]+)/([^/]+) product.php?cat=$1&brand=$2&prod=$3


这条规则允许访问者以类似这样的
url products/turntables/technics/sl1210,
来访问product.php?cat=turntables&brand=technics&prod=sl1210.

括号里为一个单元,分别对应后面的$1,$2,$3。[^/]+ 在原括号里表示除了/之外的任何一个或是多个字符。

自定义错误页面

复制代码 代码如下:

ErrorDocument 404"/404"


这是定义404页面无法找到的错误,也可以定义其他错误代码的页面。

限定访问特点资源

复制代码 代码如下:


<Files"protectedfile">
AuthName"Username and password required"
AuthUserFile/path/to/.htpasswd
Require valid-user
AuthType Basic
</Files>



保护protectedfile,authName是登陆框的提示信息,authuserfile是.htpasswd文件的路径

阻止某些ip访问

复制代码 代码如下:


order allow,deny
deny from 192.168.0.1
allow from allOrder



告诉apache指令的顺序。这里的这个是先允许后拒绝的。虽然allow from all后出现但是还是在前面生效。拒绝了192.168.0.1的访问。也可以按段来屏蔽访问的,只要只指定前面的几段就可以类似,192.168.

实现缓存

复制代码 代码如下:


ExpiresActive on
ExpiresByType image/gif "access plus 1 month"
ExpiresByType image/png "access plus 1 month"
ExpiresByType image/jpg "access plus 1 month"
ExpiresByType image/jpeg "access plus 1 month"



第一行开启,下面分别控制各种资源都加上一个月的缓存期。这个功能依赖apache的mod_expires 模块。


认证举例
如果你只是为了知道如何认证,而直接从这里开始看的,有很重要的一点需要注意,有一种常见的误解,认为实现密码认证必须要使用.htaccess文件,其实是不正确的。把认证指令放在主配置文件的<Directory>段中是一个更好的方法,而.htaccess文件应该仅仅用于无权访问主配置文件的时候。参见上述关于何时应该与何时不应该使用.htaccess文件的讨论。
有此声明在先,如果你仍然需要使用.htaccess文件,请继续看以下说明。

.htaccess文件的内容:

复制代码 代码如下:


AuthType Basic
AuthName "Password Required"
AuthUserFile /www/passwords/password.file
AuthGroupFile /www/passwords/group.file
Require Group admins



必须设置 AllowOverride AuthConfig 以允许这些指令生效。
服务器端包含(SSI)举例
.htaccess文件的另一个常见用途是允许一个特定的目录使用服务器端包含(SSI),可以在需要的目录中放置.htaccess文件,并作如下配置:

复制代码 代码如下:


Options +Includes
AddType text/html shtml
AddHandler server-parsed shtml



注意,必须同时设置 AllowOverride Options 和 AllowOverride FileInfo 以使这些指令生效。

指令的作用范围.htaccess文件中的配置指令作用于.htaccess文件所在的目录及其所有子目录,但是很重要的、需要注意的是,其上级目录也可能会有.htaccess文件,而指令是按查找顺序依次生效的,所以一个特定目录下的.htaccess文件中的指令可能会覆盖其上级目录中的.htaccess文件中的指令,即子目录中的指令会覆盖父目录或者主配置文件中的指令。

例子:

复制代码 代码如下:

/www/htdocs/example1


目录中的.htaccess

文件有如下内容:
Options +ExecCGI

(注意:必须设置"AllowOverride Options"以允许在.htaccess中使用"Options"指令)
/www/htdocs/example1/example2目录中的.htaccess文件有如下内容:
Options Includes

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

相关文章

小说网站为什么大多都部署在美国服务器

选择美国服务器部署小说网站平台的理由:1. 美国服务器性价比高,能够有效降低硬件方面的投入成本。2. 美国服务器的线路稳定,支持大带宽和CN2直连线路,最大限度的降低网络的延迟,降低了采集工具的内容采...

香港新世界电讯机房有效防范DDoS攻击

众所周知,网络攻击对企业网站都有着致命的影响。其中,DDoS攻击就是最常见也是很难防御的一种。香港服务器作为企业首选的网站建设平台,同样面临着DDoS攻击的威胁。那么对于香港服务器托管的用户来说,如何...

网站域名空间使用不足怎么办

网站域名空间使用不足解决的方法:1、删除已知没用的数据,图片,帖子等文件;2、文件删除完了还是无法保持正常运营,则需要升级网站空间,看主机商能不能提供直接升级服务,如果不可以则需要进行所有的数据迁移;...

租用美国服务器需要注意哪些事项

租用美国服务器需要注意的事项有:1、注意美国服务器机房是否正规,尽可能选择知名且口碑较好的美国服务器机房,能有效保障数据的安全;2、注意按照自身需求选择合适的美国服务器,避免造成资源浪费;3、注意选择...

云南服务器租用怎么防御网络攻击

云南服务器租用防御网络攻击的方法:1、访问控制策略首先应该做好服务器的访问控制,即设置强大的用户权限和密码策略,以防止攻击者获取服务器的访问权限。2、更新系统其次,要按照安全要求进行系统的更新,及时更...

香港主机空间为什么这么受站长亲睐

香港主机空间受站长亲睐的原因有:1、香港主机空间不用备案,能节省繁琐的备案的过程和时间,实现即开即用;2、香港主机空间国际出口宽带资源充足,国内访问速度快,能满足网站用户的访问需求;3、香港主机空间性...