php中的.htaccess文件的运用

伪静态
干后端的同学都知道伪静态这个词。何为伪静态,简单来说,就是把后缀为php的的路由,伪装成.html,或者,在一些php的框架中,入口文件为index.php的文件直接隐藏了。让用户不知道从直观上来看并知道你的项目是哪语言开发的。
再都,如果从seo方面来说,搜索引擎更喜欢爬html的静态文件。所以,做好伪静态还是很有好处的。
其实,按我的理解,.htaccess实现的伪静态,可以理解为在一些php框架的路由

#先来一段伪静态的语法
RewriteEngine On #这一行可以简单理解为伪静态的开始,就好比我们的
RewriteRule ^news/info_([0-9]{1,})\.html$ news/info.php?id=$1
#该语法表示,当访问 /neews/info.php?id=6 的时候 直接会路由于 /news/info_6.html

首先,我得先说明一下,要想实现伪静态,我们必须先在apache的配置文件那儿做一些设置
php中的.htaccess文件的运用_第1张图片
在httpd.conf的文件中,做如下配置

#搜索 rewrite_module 把前面的#号打开,表示开启
LoadModule rewrite_module modules/mod_rewrite.so
<Directory "${SRVROOT}/cgi-bin">
    AllowOverride All #此处改为All 原来是 none的
    Options None
    Require all granted
</Directory>

然后,改了httpd.conf的配置之后,记得一定得重启你的apache服务,不然不会生效。

OK,这个http.conf设置完之后,就可以在.htaccess的文件中写我们伪静态方法了。

RewriteEngine On
RewriteRule ^news/info_([a-zA-Z0-9]{1,})\.html$ news/info.php?id=$1 #a-zA-Z0-9表示数符串包函了英文和数据,建议也这么写,在整型和字符串中通用
RewriteRule ^tp_([a-zA-Z0-9]{1,})-([a-zA-Z0-9]{1,})\.html$ news/twoParams.php?a=$1&b=$2 #定义多个参数的情况[最后路由到 /tp_qrg6ge-gee3gegeg.html]
RewriteRule ^index\.html$ index.php #将index.php伪装成index.html
ErrorDocument 404 /error-pages/not-found.html #定义404错误的页面
ErrorDocument 503 /503.html #定义503的页面
DirectoryIndex myHome.html #重新定义首页,即(让index.php或者index.html 变更为 myHome.html)
Redirect a.html b.html #当访问a.html时会重定向到b.html

定义错误文件
很多时候,我们需要自定义一些错误的文件,比如404,500等这些文件时,我们可以直接在.htaccess文件中写,并不需要在项目的代码中去判断

ErrorDocument 404 /errors/error404.html
ErrorDocument 500 /errors/error500.html
//如果还有其他错误的页面,可以继续在这儿往下写即可
#关于htaccess的其他用方,比如说禁止文件目录访问等等,这此请参考下面的地址,因为我也还没学会
#参考 https://www.cnblogs.com/adforce/archive/2012/11/23/2784664.html

目录加密
htaccess还有一个鲜为人知的功能就是它可以实现对某一目录进行加密。当.htaccess文件放到某一目录下的时候,是可以对当前的目录文件进行加密的。也就是说,当你需要访问该目录时,需要输入正确的用户名和密码才能访问。(需要注意,这儿所说的用户名和密码并非在系统里面的用户名和密码)

//比如,我需要对我项目中的 test目录下面的文件进行加密,那么,我们可以这样做
//在test目录下面新建一个.htaccess 文件,同时,在该文件下面写下面的代码(注,这个是windows 环竟的)
AuthName "Login"
AuthType basic
AuthUserFile "D:\user.txt" #这个路径就是你存放密码的文件,文件最好不要放到你的项目目录下面
require valid-user

然后,在apache下面的bin目录,用dos命令执行
php中的.htaccess文件的运用_第2张图片

//命令
htpasswd -cmdps 密码文件的绝对路径 用户名
//之后会让你输入密码
//完工

之后,访问该目录下的文件时,会出现以下的框
php中的.htaccess文件的运用_第3张图片

你可能感兴趣的:(php,apache,开发语言)