前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >htaccess简介和16个小技巧

htaccess简介和16个小技巧

作者头像
用户7657330
发布2020-08-14 11:19:47
1.1K0
发布2020-08-14 11:19:47
举报
文章被收录于专栏:程序生涯

htaccess文件是Apache服务器中的一个配置文件,它负责相关目录下的网页配置。

通过htaccess文件,可以帮我们实现:

网页301重定向、

自定义404错误页面、

改变文件扩展名、

允许/阻止特定的用户或者目录的访问、

禁止目录列表、

配置默认文档等功能。

Unix、Linux系统或者是任何版本的Apache Web服务器都是支持.htaccess的,但是有的主机服务商可能不允许你自定义自己的.htaccess文件。

启用.htaccess,需要修改httpd.conf,启用AllowOverride,并可以用 AllowOverride限制特定命令的使用。如果需要使用.htaccess以外的其他文件名,可以用AccessFileName指令来改变。例 如,需要使用.config ,则可以在服务器配置文件中按以下方法配置:AccessFileName .config 。

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

Apache有一堆参数可以让你配置出几乎随心所欲的功能。.htaccess 配置文件坚持了Unix的一个文化——使用一个ASCII 的纯文本文件来配置你的网站的访问策略。

另外,因为.htaccess 是一个相当强大的配置文件,所以,一个轻微的语法错误会造成你整个网站的故障,所以,在你修改或是替换原有的文件时,一定要备份旧的文件,以便出现问题的时候可以方便的恢复。

1. 使用.htaccess 创建自定义的出错页面。

对于Linux Apache来说这是一项极其简单的事情。使用下面的.htaccess语法你可以轻松的完成这一功能。(把.htaccess放在你的网站根目录下)

代码语言:javascript
复制
ErrorDocument 401 /error/401.php

ErrorDocument 403 /error/403.php

ErrorDocument 404 /error/404.php

ErrorDocument 500 /error/500.php

2. 设置网站的时区

代码语言:javascript
复制
SetEnv TZ America/Houston 

3. 阻止IP列表

有些时候,你需要以IP地址的方式阻止一些访问。无论是对于一个IP地址还是一个网段,这都是一件非常简单的事情,如下所示:

代码语言:javascript
复制
allow from all

deny from 145.186.14.122

deny from 124.15

Apache对于被拒绝的IP会返回403错误。

4. 把一些老的链接转到新的链接上——搜索引擎优化SEO

代码语言:javascript
复制
Redirect 301 /d/file.html http://www.htaccesselite.com/r/file.html 

5. 为服务器管理员设置电子邮件。

代码语言:javascript
复制
ServerSignature EMail

SetEnv SERVER_ADMIN default@domain.com

6. 使用.htaccess 访止盗链。

如果你网站上的一个图片被别的N多的网站引用了,那么,这很有可能会导致你服务器的性能下降,使用下面的代码可以保护某些热门的链接不被过多的引用。

代码语言:javascript
复制
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 的所有请求

代码语言:javascript
复制
## .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地址的请求重定向到别的站点

代码语言:javascript
复制
ErrorDocument 403 http://www.youdomain.com

Order deny,allow

Deny from all

Allow from ip

Allow from ip

9. 直接找开文件而不是下载 – 通常,我们打开网上文件的时候总是会出现一个对话框问我们是下载还是直接打开,使用下面的设置就不会出现这个问题了,直接打开。

代码语言:javascript
复制
AddType application/octet-stream .pdf

AddType application/octet-stream .zip

AddType application/octet-stream .mov

10. 修改文件类型 – 下面的示例可以让任何的文件都成为PHP那么被服务器解释。比如:myphp, cgi,phtml等。

代码语言:javascript
复制
ForceType application/x-httpd-php

SetHandler application/x-httpd-php

11. 阻止存取.htaccess 文件

代码语言:javascript
复制
# secure htaccess file

order allow,deny

deny from all

12. 保护服务器上的文件被存取

代码语言:javascript
复制
# prevent access of a certain file order allow,deny

deny from all

13. 阻止目录浏览

代码语言:javascript
复制
# prevent access of a certain file order allow,deny

deny from all

14. 设置默认主页

代码语言:javascript
复制
# serve alternate default index page

DirectoryIndex about.html

15. 口令认证 – 你可以创建一个文件用于认证。

下面是一个示例:

代码语言:javascript
复制
# 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. 把老的域名转向新的域名

代码语言:javascript
复制
# redirect from old domain to new domain

RewriteEngine On

RewriteRule ^(.*)$ http://www.yourdomain.com/$1 [R=301,L] 
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019/03/04 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • htaccess文件是Apache服务器中的一个配置文件,它负责相关目录下的网页配置。
  • 通过htaccess文件,可以帮我们实现:
  • 网页301重定向、
  • 自定义404错误页面、
  • 改变文件扩展名、
  • 允许/阻止特定的用户或者目录的访问、
  • 禁止目录列表、
  • 配置默认文档等功能。
  • Apache有一堆参数可以让你配置出几乎随心所欲的功能。.htaccess 配置文件坚持了Unix的一个文化——使用一个ASCII 的纯文本文件来配置你的网站的访问策略。
  • 另外,因为.htaccess 是一个相当强大的配置文件,所以,一个轻微的语法错误会造成你整个网站的故障,所以,在你修改或是替换原有的文件时,一定要备份旧的文件,以便出现问题的时候可以方便的恢复。
  • 1. 使用.htaccess 创建自定义的出错页面。
  • 2. 设置网站的时区
  • 3. 阻止IP列表
  • 4. 把一些老的链接转到新的链接上——搜索引擎优化SEO
  • 5. 为服务器管理员设置电子邮件。
  • 6. 使用.htaccess 访止盗链。
  • 如果你网站上的一个图片被别的N多的网站引用了,那么,这很有可能会导致你服务器的性能下降,使用下面的代码可以保护某些热门的链接不被过多的引用。
  • 7. 阻止 User Agent 的所有请求
  • 8. 把某些特殊的IP地址的请求重定向到别的站点
  • 9. 直接找开文件而不是下载 – 通常,我们打开网上文件的时候总是会出现一个对话框问我们是下载还是直接打开,使用下面的设置就不会出现这个问题了,直接打开。
  • 10. 修改文件类型 – 下面的示例可以让任何的文件都成为PHP那么被服务器解释。比如:myphp, cgi,phtml等。
  • 11. 阻止存取.htaccess 文件
  • 12. 保护服务器上的文件被存取
  • 13. 阻止目录浏览
  • 14. 设置默认主页
  • 15. 口令认证 – 你可以创建一个文件用于认证。
  • 16. 把老的域名转向新的域名
相关产品与服务
云服务器
云服务器(Cloud Virtual Machine,CVM)提供安全可靠的弹性计算服务。 您可以实时扩展或缩减计算资源,适应变化的业务需求,并只需按实际使用的资源计费。使用 CVM 可以极大降低您的软硬件采购成本,简化 IT 运维工作。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档