• 欢迎加“百元导航”为主页,windows8风格,0.3s极速加载
  • 王柏元的博客专用搜索引擎:极客人,就用“极客搜”!
  •    2年前 (2015-01-15)  百元百科 |   3 条评论  268 
    文章评分 0 次,平均分 0.0

     

    Apache Web 服务器可以通过 .htaccess 文件来操作各种信息,这是一个目录级配置文件的默认名称,允许去中央化的 Web 服务器配置管理。可用来重写服务器的全局配置。该文件的目的就是为了允许单独目录的访问控制配置,例如密码和内容访问。在做网站的时候常常用到很多.htaccess 规则,我给大家总结了21 个非常有用的 .htaccess 提示和技巧

    下面是 21 个非常有用的 .htaccess 配置的提示和技巧:

    1. 定制目录的 Index 文件

     

     

    你可以使用上面的配置来更改目录的默认页面,例如你将这个脚本放在 foo 目录,则用户请求 /foo/ 时候就会访问 /foo/index.html。

    2. 自定义错误页


     

    当用户访问页面报错时,例如页面找不到你希望显示自定义的错误页面,你可以通过这种方法来实现。或者是动态的页面:


     

    3. 控制访问文件和目录的级别

    .htaccess 经常用来限制和拒绝访问某个文件和目录,例如我们有一个 includes 文件夹,这里存放一些脚本,我们不希望用户直接访问这个文件夹,那么通过下面的脚本可以实现:


     

    上述脚本是拒绝所有的访问,你也可以根据IP段来拒绝:


     

    一般这些方法是通过防火墙来处理,但在一个生产环境中的服务器来说,这样的调整非常方便。

    有时候你只是想禁止某个ip访问:


     

    4. 修改环境变量

    环境变量包含了服务器端 CGI 的一些扩展信息,可使用 SetEnv 和 UnSetEnv 进行设置以及取消设置.


     

    5. 301 重定向

    如果你希望某个页面跳转到新的页面:


     

    下面可以实现对整个路径的重定向


     

    6. 通过 .htaccess 实现缓存策略

    通过设置在浏览器上缓存静态文件可以提升网站的性能:


     

    7. 使用 GZIP 对输出进行压缩

    在 .htaccess 中添加下面的代码可以将所有的 css、js 和 html 使用 GZIP 算法压缩:


     

    使用上面代码的前提是启用 mod_gzip 模块,你可以使用下面脚本来判断 Web 服务器是否提供 mod_deflate 支持:


     

    如果 Web 服务器不支持 mod_deflate ,那么可使用下面方法:


     

    更多关于压缩的内容请阅读: Compressing PHP, CSS, JavaScript(JS).

    8. 强制要求使用 HTTPS 访问

    通过以下脚本可以强制整个网站必须使用 https 方式访问:


     

    9. URL 重写

    例如要将 product.php?id=12 重写为 product-12.html


     

    将 product.php?id=12 重写为 product/ipod-nano/12.html


     

    重定向没有 www 到有 www 的 URL 地址:


     

    重写 yoursite.com/user.php?username=xyz 到 yoursite.com/xyz


     

    重定向某个域名到一个 public_html 里新的子文件夹:


     

    10. 阻止列出目录文件

    使用下面代码可以防止列表目录里的所有文件:


     

    或者


     

    更多详情 Denying/Allowing directory listing.

    11. 添加新的 MIME-Types

    MIME-types 依赖于文件的扩展名,未能被识别的文件扩展名会当成文本数据传输


     

    12. 防盗链

    你不希望别人网站引用你站内的图片、css 等静态文件,也就是传说中的防盗链,可以使用如下脚本:


     

    13. 指定上传文件的大小限制,适用于 PHP


     

    上述脚本中,通过四个参数来设置上传文件的限制,第一个参数是文件的大小,第二个是 POST 数据的大小,第三个是传输的时间(单位秒),最后一个是解析上传数据最多花费的时间(单位秒)

    14. 禁止脚本执行


     

    15. 修改字符集和语言头


     

    16. 设置服务器时区(GMT)


     

    17. 强制 “File Save As” 提示


     

    18. 保护单个文件

    正常情况下 .htaccess 可用于限制整个目录的访问,但也可以只限制某个文件:


     

    19. 设置 Cookie

    通过环境变量来设置 Cookie


     

    基于请求设置 Cookie,该代码发送 Set-Cookie 头用于设置 Cookie 值为第二个括号里的匹配项


     

    20. 设置自定义的响应 Headers


     

    21. 根据 User-Agent 来阻止请求


     

    英文原文, OSCHINA原创翻译

     

    <filesmatch ".(ico|pdf|flv|jpg|jpeg|png|gif|swf|mp3|mp4)$"=""><filesmatch ".(html|htm|xml|txt|xsl)$"=""><filesmatch ".(js|css)$"=""><filesmatch ".(txt|html|htm|php)"="">

     

    除特别注明外,本站所有文章均为王柏元的博客原创,转载请注明出处来自http://wangbaiyuan.cn/21_htaccess-_skills.html

    关于
    记录生活,镌刻心路;泼洒文墨,分享技术!王柏元的博客致力于IT经验交流,并原创翻译引进外文文章,打开IT国际化视野

    发表评论

    格式
    1. 很不错,看上去好全面,收藏了

      简单生活 评论达人 LV.1 2年前 (2015-03-08) [1] [0]
    2. MARK一下,感謝分享!!話說你的網站字體非常不錯耶!也歡迎訪問小站 AREFLY.COM ~ :oops:

      超級efly 评论达人 LV.1 2年前 (2015-02-03) [0] [0]

    登录

    忘记密码 ?

    您也可以使用第三方帐号快捷登录

    切换登录

    注册