热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Apache.htaccess文件功能用法介绍

htaccess文件是apache环境中的一个重的功能了,特别是针对有很多空间的服务器,是必须让每个空间可以自定义htaccess文件的一些功能的,以下介绍htaccess的使用方法。

.htaccess文件是apache环境中的一个重的功能了,特别是针对有很多空间的服务器,是必须

让每个空间可以自定义.htaccess文件的一些功能的,以下介绍.htaccess的使用方法。.htaccess apache默认是不支持的,如果要支持我们需在于apache中打开。

1,如何让的本地APACHE支持.htaccess

如何让的本地APACHE器支持.htaccess文件呢?其实只要简朴修改一下apache的httpd.conf设置就让APACHE支持.htaccess文件了,来看看操作。

(1)打开httpd.conf(在那里? APACHE目录的CONF目录里面),用文本编纂器打开后,查找 

  1. Options FollowSymLinks  
  2. AllowOverride None 

改为 

  1. Options FollowSymLinks  
  2. AllowOverride All 

(2)去掉下面的注释 

  1. LoadModule rewrite_module modules/mod_rewrite.so 

将以下相应代码放到对应目录中的.htaccess文件,即可实现相应功能。

关闭错误显示:

php_flag display_startup_errors off

php_flag display_errors off

php_flag html_errors off

php_value docref_root 0

php_value docref_ext 0

只显示PHP错误:

php_flag  display_errors  on

php_flag  display_startup_errors on

php_value error_reporting  2047

其中,“2047”为要显示的错误的级别,详细表格如下:

1 E_ERROR

2 E_WARNING

4 E_PARSE

8 E_NOTICE

16 E_CORE_ERROR

32 E_CORE_WARNING

64 E_COMPILE_ERROR

128 E_COMPILE_WARNING

256 E_USER_ERROR

512 E_USER_WARNING

1024 E_USER_NOTICE

2047 E_ALL

2048 E_STRICT

4096 E_RECOVERABLE_ERROR

要把错误保存到日志文件中,可以这样设置:

  1. # enable PHP error logging 
  2. php_flag  log_errors on 
  3. php_value error_log  /home/path/public_html/domain/PHP_errors.log 

然后,可以设置不允许访问.log文件:

  1. # prevent access to PHP error log 
  2. Order allow,deny 
  3. Deny from all 
  4. Satisfy All 

设置错误日志的最大体积,以bytes为单位:

  1. # general directive for setting max error size 
  2. log_errors_max_len integer 

综合上述,.htaccess的PHP错误显示设置汇总:

  1. # PHP error handling for production servers 
  2. # disable display of startup errors 
  3. php_flag display_startup_errors off 
  4. # disable display of all other errors 
  5. php_flag display_errors off 
  6. # disable html markup of errors 
  7. php_flag html_errors off 
  8. # enable logging of errors 
  9. php_flag log_errors on 
  10. # disable ignoring of repeat errors 
  11. php_flag ignore_repeated_errors off 
  12. # disable ignoring of unique source errors 
  13. php_flag ignore_repeated_source off 
  14. # enable logging of php memory leaks 
  15. php_flag report_memleaks on 
  16. # preserve most recent error via php_errormsg 
  17. php_flag track_errors on 
  18. # disable formatting of error reference links 
  19. php_value docref_root 0 
  20. # disable formatting of error reference links 
  21. php_value docref_ext 0 
  22. # specify path to php error log 
  23. php_value error_log /home/path/public_html/domain/PHP_errors.log 
  24. # specify recording of all php errors 
  25. php_value error_reporting 999999999 
  26. # disable max error string length 
  27. php_value log_errors_max_len 0 
  28. # protect error log by preventing public access 
  29. Order allow,deny 
  30. Deny from all 
  31. Satisfy All 

以下则是适合开发者应用的设置:

  1. # PHP error handling for development servers 
  2. php_flag display_startup_errors on 
  3. php_flag display_errors on 
  4. php_flag html_errors on 
  5. php_flag log_errors on 
  6. php_flag ignore_repeated_errors off 
  7. php_flag ignore_repeated_source off 
  8. php_flag report_memleaks on 
  9. php_flag track_errors on 
  10. php_value docref_root 0 
  11. php_value docref_ext 0 
  12. php_value error_log /home/path/public_html/domain/PHP_errors.log 
  13. php_value error_reporting 999999999 
  14. php_value log_errors_max_len 0 
  15. Order allow,deny 
  16. Deny from all 
  17. Satisfy All 

一、错误文档的定位

(1)、常用的客户端请求错误返回代码:

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

(2)、常见的服务器错误返回代码:

500 Internal Server Error

(3)、用户可以利用.htaccess指定自己事先制作好的错误提醒页面。一般情况下,人们可以专门设立一个目录,例如errors放置这些页面。然后再.htaccess中,加入如下的指令:

ErrorDocument 404 /errors/notfound.html ErrorDocument 500

/errors/internalerror.html 一条指令一行。

上述第一条指令的意思是对于404,也就是没有找到所需要的文档的时候得显示页面为/errors目录下的notfound.html页面。不难看出语法格式为:

ErrorDocument 错误代码 /目录名/文件名.扩展名 如果所需要提示的信息很少的话,不必专门制作页面,直接在指令中使用HTML号了,例如下面这个例子:

  1. ErrorDocument 401 "  
  2. 你没有权限访问该页面!  
  3. "  

二、文档访问的密码保护要利用.htaccess对某个目录下的文档设定访问用户和对应的密码,首先要做的是生成一个.htpasswd的文本文档,例如:

zheng:y4E7Ep8e7EYV 这里密码经过加密,用户可以自己找些工具将密码加密成.htaccess支持的编码。该文档最好不要放在www目录下,建议放在www根目录文档之外,这样更为安全些。

有了授权用户文档,可以在.htaccess中加入如下指令了:

AuthUserFile .htpasswd的服务器目录 AuthGroupFile /dev/null (需要授权访问的目录) AuthName EnterPassword AuthType Basic (授权类型) require user wsabstract (允许访问的用户,如果希望表中所有用户都允许,可以使用 require valid-user)

注:括号部分为学习时候自己添加的注释

三、拒绝来自某个IP的访问

如果我不想某个政府部门访问到我的站点的内容,那可以通过.htaccess中加入该部门的IP而将它们拒绝在外。 例如:

order allow,deny deny from 210.21.112.43deny from 219.146.95 allow from all 注: 第二行拒绝某个IP,第三行拒绝某个IP段,也就是219.146.95.0~219.146.95.255 想要拒绝所有人?用deny from all好了。不止用IP,也可以用域名来设定。

四、保护.htaccess文档

在使用.htaccess来设置目录的密码保护时,它包含了密码文件的路径。从安全考虑,有必要把.htaccess也保护起来,不让别人看到其中的内容。虽然可以用其他方式做到这点,比如文档的权限。不过,.htaccess本身也能做到,只需加入如下的指令:

  1.  order allow,deny deny from all   

五、URL转向

我们可能对网站进行重新规划,将文档进行了迁移,或者更改了目录。这时候,来自seo/seo.html" target="_blank">搜索引擎或者其他网站链接过来的访问就可能出错。这种情况下,可以通过如下指令来完成旧的URL自动转向到新的地址:Redirect /旧目录/旧文档名 新文档的地址 或者整个目录的转向: Redirect 旧目录 新目录 改变缺省的首页文件 一般情况下缺省的首页文件名有default、index等。不过,有些时候目录中没有缺省文件,而是某个特定的文件名,比如在pmwiki中是pmwiki.php。这种情况下,要用户记住文件名来访问很麻烦。在.htaccess中可以轻易的设置新的缺省文件名:

DirectoryIndex 新的缺省文件名 也可以列出多个,顺序表明它们之间的优先级别.


推荐阅读
  • 如何实现织梦DedeCms全站伪静态
    本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • CentOS 7部署KVM虚拟化环境之一架构介绍
    本文介绍了CentOS 7部署KVM虚拟化环境的架构,详细解释了虚拟化技术的概念和原理,包括全虚拟化和半虚拟化。同时介绍了虚拟机的概念和虚拟化软件的作用。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 禁止程序接收鼠标事件的工具_VNC Viewer for Mac(远程桌面工具)免费版
    VNCViewerforMac是一款运行在Mac平台上的远程桌面工具,vncviewermac版可以帮助您使用Mac的键盘和鼠标来控制远程计算机,操作简 ... [详细]
  • 本文介绍了使用PHP实现断点续传乱序合并文件的方法和源码。由于网络原因,文件需要分割成多个部分发送,因此无法按顺序接收。文章中提供了merge2.php的源码,通过使用shuffle函数打乱文件读取顺序,实现了乱序合并文件的功能。同时,还介绍了filesize、glob、unlink、fopen等相关函数的使用。阅读本文可以了解如何使用PHP实现断点续传乱序合并文件的具体步骤。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 本文介绍了在Windows环境下如何配置php+apache环境,包括下载php7和apache2.4、安装vc2015运行时环境、启动php7和apache2.4等步骤。希望对需要搭建php7环境的读者有一定的参考价值。摘要长度为169字。 ... [详细]
  • mac php错误日志配置方法及错误级别修改
    本文介绍了在mac环境下配置php错误日志的方法,包括修改php.ini文件和httpd.conf文件的操作步骤。同时还介绍了如何修改错误级别,以及相应的错误级别参考链接。 ... [详细]
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • PHP设置MySQL字符集的方法及使用mysqli_set_charset函数
    本文介绍了PHP设置MySQL字符集的方法,详细介绍了使用mysqli_set_charset函数来规定与数据库服务器进行数据传送时要使用的字符集。通过示例代码演示了如何设置默认客户端字符集。 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
author-avatar
王诗昀彦廷
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有