?? 简单的说,.htaccess 就是一个文件,使用它可以更改服务器的设置,允许你做许多不同的事情,比如说您可以利用.htaccess文件创建自定义的404错误页面等。 ???防盗链可以使用----使用rewrite,需要增加apache的mode_rewrite,支持.htaccess文件目录权限限制 首先要确认你的服务器或空间的服务器解译引擎为Apache2,还有支持.htaccess客户设置文件, 接下就是做一个 .htaccess 文件了,其 .htaccess 文件内容为 RewriteEngine on 其中有色的地方都是要改为你的: 这个方法有个好处是,不同的虚拟主机用不同的描述定义。 接下就是怎么用 .htaccess 文件来实现防盗链了。 ? 如何判断你的主机是否支持.htaccess 判断你的主机是否允许.htaccess,一个标志很好的是它是否支持文件夹密码保护。为达到此功能,主机服务商需要使用.htaccess(当然,少数情况下他们虽提供密码保护功能,但却并不允许你使用. htaccess)。如果你不确定自己的主机是否支持.htaccess,最好的办法是上传你自己的.htaccess文件看看是否有用,或者直接发送e-mail向你的主机服务商咨询。 Apache系统中的.htaccess文件(也称为“分布式配置文件”)提供了针对目录改变配置的方法,即在一个特定的文档目录中放置一个包含一个或多个指令的文件,以作用于此目录及其所有子目录。作为用户,所能使用的命令受到限制。管理员可以通过Apache的 AllowOverride指令来设置。 配置.htaccess需要注意的一些问题 ? apache中.htaccess文件的功能写法 - 子目录中的指令会覆盖更高级目录或者主服务器配置文件中的指令。 - .htaccess必须以ASCII模式上传,最好将其权限设置为644。 常用的客户端请求错误返回代码: 用户可以利用.htaccess指定自己事先制作好的错误提醒页面。一般情况下,人们可以专门设立一个目录,例如errors放置这些页面。然后再.htaccess中,加入如下的指令: ErrorDocument 404 /errors/notfound 一条指令一行。上述第一条指令的意思是对于404,也就是没有找到所需要的文档的时候得显示页面为/errors目录下的notfound页面。不难看出语法格式为: ErrorDocument 错误代码 /目录名/文件名.扩展名 如果所需要提示的信息很少的话,不必专门制作页面,直接在指令中使用HTML号了,例如下面这个例子: ErrorDocument 401 "<body bgcolor=#ffffff><h1>你没有权限访问该页面,请放弃!</h1></body>" 文档访问的密码保护 要利用.htaccess对某个目录下的文档设定访问用户和对应的密码,首先要做的是生成一个.htpasswd的文本文档,例如: zheng:y4E7Ep8e7EYV 这里密码经过加密,用户可以自己找些工具将密码加密成.htaccess支持的编码。该文档最好不要放在www目录下,建议放在www根目录文档之外,这样更为安全些。 有了授权用户文档,可以在.htaccess中加入如下指令了: AuthUserFile .htpasswd的服务器目录 require user wsabstract (允许访问的用户,如果希望表中所有用户都允许,可以使用 require valid-user) 注,括号部分为学习时候自己添加的注释 拒绝来自某个IP的访问 如果我不想某个政府部门访问到我的站点的内容,那可以通过.htaccess中加入该部门的IP而将它们拒绝在外。 例如: order allow,deny 第二行拒绝某个IP,第三行拒绝某个IP段,也就是219.146.95.0~219.146.95.255 想要拒绝所有人?用deny from all好了。不止用IP,也可以用域名来设定。 保护.htaccess文档 在使用.htaccess来设置目录的密码保护时,它包含了密码文件的路径。从安全考虑,有必要把.htaccess也保护起来,不让别人看到其中的内容。虽然可以用其他方式做到这点,比如文档的权限。不过,.htaccess本身也能做到,只需加入如下的指令: <Files .htaccess> URL转向 我们可能对网站进行重新规划,将文档进行了迁移,或者更改了目录。这时候,来自搜索引擎或者其他网站链接过来的访问就可能出错。这种情况下,可以通过如下指令来完成旧的URL自动转向到新的地址: Redirect /旧目录/旧文档名 新文档的地址 或者整个目录的转向: Redirect 旧目录 新目录 改变缺省的首页文件 一般情况下缺省的首页文件名有default、index等。不过,有些时候目录中没有缺省文件,而是某个特定的文件名,比如在pmwiki中是pmwiki.php。这种情况下,要用户记住文件名来访问很麻烦。在.htaccess中可以轻易的设置新的缺省文件名: DirectoryIndex 新的缺省文件名 也可以列出多个,顺序表明它们之间的优先级别,例如: DirectoryIndex filename index.cgi index.pl default.htm 防止盗链 如果不喜欢别人在他们的网页上连接自己的图片、文档的话,也可以通过htaccess的指令来做到。 所需要的指令如下: RewriteEngine on 如果觉得让别人的页面开个天窗不好看,那可以用一张图片来代替: RewriteEngine on
在虚拟主机根目录增加.htaccess文件,描述从定向,把非本地地址refer的图片文件都从定向到警告图片或者警告网页上。
如果你有自己的服务器就请先对./conf/httpd.conf 文件做以下修改
找到:#LoadModule rewrite_module modules/mod_rewrite.so
把前面的 # 给去丢
找到等一个 AllowOverride None 改为 AllowOverride All
重启Apache2服务器
RewriteCond %{HTTP_REFERER} !^http://aaoo.net/.*$ [NC]
RewriteCond %{HTTP_REFERER} !^http://aaoo.net$ [NC]
RewriteCond %{HTTP_REFERER} !^http://www.aaoo.net/.*$ [NC]
RewriteCond %{HTTP_REFERER} !^http://www.aaoo.net$ [NC]
RewriteRule .*.(jpg|jpeg|gif|png|bmp|rar|zip|exe)$http://down.yoyo.com.ru/err[R,NC]
红色:就是改为你提供下载页面的地址,也就是只有通过这个地址才可以下载你所提供的东东。
蓝色:就是要保护文件的扩展名(以|分开),也就是说以这些为扩展名的文件只有通过红色的地址才可以访问。
绿色:如果不是通过红色的地址访问蓝色这些为扩展名的文件时就回重定向到绿色地址上。
首先要在空间上建两个目录(当然目录名随你),一个为 web 另一个为 down ,
web 是用来放下载页面的(或下载程序),down 当然就是放你提供的东东的啦,
把 .htaccess 文件的红色部分改一下,改为http://你的域名/web。蓝色部分
改为你要保护文件的扩展名。绿色部分改为http://你的域名/web。改后保存
.htaccess 文件把它上传到 down 目录。
- .htaccess 文件(或者"分布式配置文件"提供了针对目录改变配置的方法,即,在一个特定的文档目录中放置一个包含一个或多个指令的文件,以作用于此目录及其所有子目录。作为用户,所能使用的命令受到限制。管理员可以通过Apache的AllowOverride指令来设置。
?
错误文档的定位
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
ErrorDocument 500 /errors/internalerror
AuthGroupFile /dev/null (需要授权访问的目录)
AuthName EnterPassword
AuthType Basic (授权类型)
deny from 210.21.112.43
deny from 219.146.95
allow from all
order allow,deny
deny from all
</Files>
RewriteCond % !^$
RewriteCond % !^http://(www.)?phpv.net/.*$?[NC]
RewriteRule .(gif|jpg)$ - [F]
RewriteCond % !^$
RewriteCond % !^http://(www.)?mydomain.com/.*$?[NC]
RewriteRule .(gif|jpg)$http://www.phpv.net/img_PageNotFound.gif[R,L]
详细解决方案
.htaccess资料
热度:3743 发布时间:2013-02-26 00:00:00.0
相关解决方案
- 十 个实用的 .htaccess 代码片段
- 21个十分有用的 .htaccess 提示和技巧
- Drupal .htaccess rewrite 规约分析
- 常见的 .htaccess 应用技巧
- 分享几条伪静态守则的写法 .htaccess
- php mvc 透过 htaccess 隐藏 index.php 或 index.php?arg=
- htaccess 伪静态跳转有关问题
- .htaccess 小弟我写的重定向如何不起作用
- .htaccess 如何跳转
- .htaccess rewrite规则有关问题
- .htaccess url中带有特殊字符的有关问题
- htaccess URL重新有关问题
- 如何才能使用.htaccess
- .htaccess 可以不可以将静态的URL转到动态的?解决方案
- 设置.htaccess 禁止访问网站根上面的某个php文件
- .htaccess 有关问题
- .htaccess 的重定向有关问题
- 求 .htaccess 跳转规则解决方案
- .htaccess 文件重定向之后,小弟我的css和js都无法访问了。咋回事呢?求大家指导一下
- .htaccess 地址重写问题
- php 二级域名 .htaccess,该怎么处理
- php网站linux系统,如何禁止浏览.htaccess
- 二级域名伪静态如何弄(htaccess)
- 怎么配置.htaccess,403设定为什么只有首页有效
- .htaccess rewrite 有关问题!小弟我想url 去掉?do= 直接显示后面的参数该如何写
- PHP索引里.htaccess 重定向到一个文件
- 伪静态因特网址除了 .htaccess 和 模板中连结要改,还有什么需要注意
- Url rewrite in .htaccess is not working解决方法
- Url rewrite in .htaccess is not working,该如何解决
- htaccess 伪静态跳转有关问题