.htaccess文件
前言
看了几篇文章,发现自己对于如何维护普通的服务器安全完全不会,先从简单的.htaccess来研究吧
.htaccess文件的作用,就是更改httpd.ini文件中的配置,但作用范围仅限当前文件夹
在使用.htaccess文件之前确认httpd.ini文件中AllowOverride All是否存在
.htaccess中不区分大小写
配置
访问控制
在实施访问控制时,最简单的访问控制就是
deny from all
禁止所有用户在url中访问该文件夹(包括子文件夹)
但是实际上总不可能全部都禁止(至少要让自己访问吧),总要允许一些主机访问,所以这时就需要使用allow
allow from 127.0.0.1
deny from all
实际使用中还可能会使用order,来指定allow和deny的顺序
例:
Order allow,deny
allow from 127.0.0.1
deny from all
表示先进行allow操作,在进行deny操作,这就导致所有的用户都会被禁止
而
Order deny,allow
allow from 127.0.0.1
deny from all
则会先使用deny,在进行allow操作,这就使得可以通过127.0.0.1来访问
当然也可以使用域名来替代ip
Order allow,deny
allow from .*domain\.com.*
deny from all
通过allow,deny和order的设置则可以进行控制访问
文件访问限制
有些时候需要对一些文件进行限制,使其不能让所有人都能访问
例
<files 1.txt>
order deny,allow
deny from all
allow from 127.0.0.1
</files>
限制其只能通过127.0.0.1访问
当然,支持通配符
<files *.txt>
order deny,allow
deny from all
allow from 127.0.0.1
</files>
<files [1-2].txt>
order deny,allow
deny from all
allow from 127.0.0.1
</files>
但是这样并不能对文件类型进行限制,所以,我们可以使用
<filesmatch ".txt$">
order deny,allow
deny from all
allow from 127.0.0.1
</filesmatch>
来正则匹配文件类型,总而达到禁止访问的目的
任意目录浏览
虽然说任意目录浏览可能会造成一系列的问题,但是有时候我们又不得不开启这项功能(比如列举所有的文件以供下载时)
开启
options all +indexes
禁用
options all -indexes
或
indexignore *
如果我们只想提供一部分文件下载呢?
options all +indexes
indexignore *.php
不提供php文件
定义首页文件
如果在不同的文件夹中存在不同文件名的文件,而我们又想将他们全部作为首页文件,那么可以这样写
directoryindex index222.html333
配置错误文件
访问各大站的页面,发现其404页面都有所不同,当然框架内部的实现不去考虑,仅是单纯从apache的层次实现
其实很简单
errordocument 404 /404.html
url重写
有时候我们不想让别人知道我们服务器后端脚本的类型,想将其隐藏起来,我们可以使用静态的url,或者使用restful风格的url
当然,这里只是实现简单的静态解析
比如,访问index就相当于访问index.php
RewriteEngine On
RewriteRule ^(\w+)$ $1.php
这样就隐藏了后缀名
重定向
如果想实现域名重定向,则可以这样
RewriteEngine On
RewriteRule ^(\w+)$ $1.php [r]
实现301跳转
RewriteEngine On
RewriteRule ^(\w+)$ $1.php [r=301]
实现302跳转
RewriteEngine On
RewriteRule ^(\w+)$ $1.php [r=302]
当然,跳转时也可以定义基准目录(基于网站根目录)
rewriteengine on
rewritebase /
RewriteRule ^(\w+)$ $1.php
实现静态URL
当访问127.0.0.1/index/info/1时就相当于访问127.0.0.1/index.php?info=1
rewriteengine on
RewriteRule ^(\w+)/(\w+)/(\w+)/$ $1.php?$2=$3
正则表达式
rewrite中可以使用正则表达式来进行匹配
[F] 使得服务器返回403
[L] 表示当前是最后一条规则,匹配完后停止重写
[NC] 表示当前规则中不区分大小写
[QSA] 如果加上了[qsa]了那么表示会将请求中的?转换为&
参考链接
http://lesca.me/archives/htaccess-appendix.html#htaccess_regex
.htaccess文件的更多相关文章
- 用.htaccess文件实现URL重写
注:第一部分来自 http://www.cnblogs.com/wangkongming/archive/2012/11/13/2768251.html 这位博主的个人网站简洁 还有诗歌 ...
- 在linux 服务器上用.htaccess文件实现二级域名访问子目录
实现子域名绑定网站子目录的方法有很多,比如可以用js跳转,可以用php实现,可以301跳转等,但最常用的应该是RewriteEngine方式了. 新建一个笔记本命名为.htaccess(在wind ...
- iis6上使用.htaccess文件,ISAPI_Rewrite的安装及使用
在Apache上很有用的.htaccess文件在IIS上就没有,要想实现类似的跳转功能可以使用ISAPI_Rewrite来代替,这是一个专门为IIS设置的工具,目的就是代替.htaccess实现很多功 ...
- ThinkPHP 利用.htaccess文件的 Rewrite 规则隐藏URL中的 index.php
1.首先修改Apache的httpd.conf文件. 确认httpd.conf配置文件中加载了mod_rewrite.so 模块,加载的方法是去掉mod_rewrite.so前面的注释#号 讲http ...
- apache配置rewrite及.htaccess文件(转载)
今天看到一个哥们的帖子发了个rewrite的帖子,以前也写过一个,配置挺简单的,但当时没注意这个问题,当时没有用到.htaccess文件,在机子上测试了一下,发现确实没法用,于是开始找问题的所在. 自 ...
- htaccess文件还可以被用来把访问网站的流量劫持到黑客的网站
看是否有文件上传操作(POST方法), IPREMOVED--[01/Mar/2013:06:16:48-0600]"POST/uploads/monthly_10_2012/view.ph ...
- 禁止浏览.htaccess文件
很多黑客会攻击和利用.htaccess做网站跳转,所以保护好.htaccess文件尤为重要. 在apache的httpd.conf的配置文件中 默认是已经设置了禁止对.htaccess的访问,截取相关 ...
- 在.htaccess文件中写RewriteRule无效的问题的解决
近来在Apache Rewrite 拟静态配置时,遇到个问题.写的如下: RewriteEngine onRewriteRule ^/t_(.*)/$ /test.php?id=$1 保存在httpd ...
- 创建.htaccess文件
在linux下创建.htaccess文件非常简单,直接新建一个文件并重命名为.htaccess即可. 下面我来讲下如何在Window下创建.htaccess文件 一般在本地电脑上是无法建立 .htac ...
- .htaccess文件详解
启用.htaccess,需要修改httpd.conf,启用AllowOverride,并可以用AllowOverride限制特定命令的使用 笼统地来说,.htaccess可以帮我们实现包括:文件夹密码 ...
随机推荐
- nodejs使用场景
NodeJS的工作原理其实就是事件循环.可以说每一条NodeJS的逻辑都是写在回调函数里面的,而回调函数都是有返回之后才异步执行的! 既然NodeJS处理并发的能力强,但处理计算和逻辑的能力反而很弱, ...
- tf.session.run()单函数运行和多函数运行区别
tf.session.run()单函数运行和多函数运行区别 觉得有用的话,欢迎一起讨论相互学习~Follow Me problem instruction sess.run([a,b]) # (1)同 ...
- svn工具的使用问题总结
前言: 最近在开发的时候,由于需求太多,开发周期长短不一,从主线上切了多个分支(一般不在主线trunk上开发,万一线上出问题可及时修改代码上线),在部分功能上线后,想把代码同步到新的分支上去,最开始的 ...
- C11构造函数的改善
1.委托构造函数 委托构造函数就是允许在同一个类中一个构造函数可以调用另一个构造函数,从而在初始化时简化变量的初始化. class CTest { public: int x; int y; int ...
- 如何发布一个自定义Node.js模块到NPM(详细步骤,附Git使用方法)
咱们闲话不多说,直接开始! 由于我从没有使用过MAC,所以我不保证本文中介绍的操作与MAC一致. 文章开始我先假定各位已经在window全局安装了Node.js,下面开始进行详细步骤介绍: 本文本着, ...
- 2017ACM暑期多校联合训练 - Team 6 1003 HDU 6098 Inversion (模拟)
题目链接 Problem Description Give an array A, the index starts from 1. Now we want to know Bi=maxi∤jAj , ...
- java类中访问属性
package first; public class for_protect { private int age=10; int number = 100; public void show(){ ...
- C# Selenium with PhantomJSDriver get image width and height (获取图片的长和高)
//get image width and height var image=driver.FindElement(By.ClassName("it-Header_authorImage&q ...
- [转载]Selenium実行中にJavaScriptのコードを実行する
Selenium実行中にJavaScriptのコードを実行する JavaScriptで画面の値を取得/設定するコードをメモ. WebDriverEx.cs // JavaScriptを実行(戻り値なし ...
- docker简单介绍(资料收集总结)
[前言] 首先,感谢我的leader总是会问我很多技术的基本资料,让我这个本来对于各种技术只知道操作命令不关注理论知识的人,开始重视理论资料. 关于docker的操作步骤等等,都是之前学习的,现在补上 ...