<VirtualHost *:80>
DocumentRoot "/data/wwwroot/111.com"
ServerName 111.com
<Directory /data/wwwroot/111.com> //指定认证的目录,只要111.com这个目录下面的都要认证
AllowOverride AuthConfig //这个相当于打开认证的开关,没有这一行相当于没有开启
AuthName "111.com user auth" //自定义认证的名字,作用不大
AuthType Basic //认证的类型,一般为Basic
AuthUserFile /data/.htpasswd //指定密码文件所在位置
require valid-user //指定需要认证的用户为全部可用用户
</Directory>
</VirtualHost>
再次使用curl -x: curl -x127.0.0.1:80 -uxie:123123 111.com -I 这次状态码是200,就是正常的。-u指定用户和密码
<VirtualHost *:80>
DocumentRoot "/data/wwwroot/www.123.com"
ServerName www.123.com
<FilesMatch 123.php> //跟上面的不同的是这行,上面是指定认证的目录,这里是指定单个文件。
AllowOverride AuthConfig
AuthName "123.com user auth"
AuthType Basic
AuthUserFile /data/.htpasswd
require valid-user
</FilesMatch> //这行也不同
</VirtualHost>
修改为如下图所示:
<VirtualHost *:80>
DocumentRoot "/data/wwwroot/111.com"
ServerName 111.com
ServerAlias www.example.com
<IfModule mod_rewrite.c> //需要mod_rewrite模块支持
RewriteEngine on //打开rewrite功能
RewriteCond %{HTTP_HOST} !^111.com$ //定义rewrite的条件,主机名(域名)不是111.com满足条件
RewriteRule ^/(.*)$ http://111.com/$1 [R=301,L] //定义rewrite规则,当满足上面的条件时,这条规则才会执行,301是永久重定向,302是临时重定向。L表示只跳一次,跳一次结束。
</IfModule>
</VirtualHost>
User-Agent:用户代理,比如用浏览器或curl访问,那么浏览器或curl就是用户的代理。 Referer:表示打开当前网站的上一个网站的网址。
扩展 apache虚拟主机开启php的短标签 http://ask.apelearn.com/question/5370