笔记内容:

  • 11.18 Apache用户认证

  • 11.19/11.20 域名跳转

  • 11.21 Apache访问日志

笔记日期:2017.10.09


11.18 Apache用户认证

Apache用户认证,域名跳转,Apache访问日志_Apache用户认证

用户认证是在你打开网页的时候就需要进行认证,如果没有通过认证就不允许访问网页,和网站上的登录账户不一样。这样的做法虽然可以增加安全性,但是会导致用户体验很差,因为总是要你认证完了才能访问网页,也是挺麻烦的。不过这样的需求还是有可能会遇到的,因为有些网页需要比较高的安全保证,例如后台管理员登录的入口网页。

  1. 编辑虚拟主机配置文件:

vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf


  1. 修改成如下内容:

<VirtualHost *:80>

   DocumentRoot "/data/wwwroot/111.com"

   ServerName 111.com

   <Directory /data/wwwroot/111.com> //指定认证的目录

       AllowOverride AuthConfig //这个相当于打开认证的开关

       AuthName "111.com user auth" //自定义认证的名字,作用不大

       AuthType Basic //认证的类型,一般为Basic,其他类型阿铭没用过

       AuthUserFile /data/.htpasswd  //指定密码文件所在位置

       require valid-user //指定需要认证的用户为全部可用用户

   </Directory>

</VirtualHost>

Apache用户认证,域名跳转,Apache访问日志_Apache访问日志_02


  1. 生成用户密码文件:

/usr/local/apache2.4/bin/htpasswd -c -m /data/.htpasswd user111

Apache用户认证,域名跳转,Apache访问日志_Apache用户认证_03


可以查看文件里的内容,左边的是用户名,右边的是密码,这个密码是用md5加密的:

Apache用户认证,域名跳转,Apache访问日志_Apache用户认证_04


第二次再添加用户的时候就不需要加-c选项了,因为密码文件已经创建过了:

Apache用户认证,域名跳转,Apache访问日志_Apache访问日志_05

这时查看密码文件就可以看到多了一行内容:

Apache用户认证,域名跳转,Apache访问日志_Apache用户认证_06


  1. 重新加载配置文件:

Apache用户认证,域名跳转,Apache访问日志_域名跳转_07


  1. 然后使用curl命令测试一下:

Apache用户认证,域名跳转,Apache访问日志_Apache用户认证_08

发现出现了401状态码,这是因为需要进行用户验证。


使用-I选项能看到详情:

Apache用户认证,域名跳转,Apache访问日志_Apache用户认证_09


这时候使用浏览器进行访问就会发现需要你输入用户密码进行验证了(域名需要在Windows的hosts文件里配置一下,让这个域名指向你虚拟机的IP):

Apache用户认证,域名跳转,Apache访问日志_Apache访问日志_10

Apache用户认证,域名跳转,Apache访问日志_Apache用户认证_11

需要输入刚刚设置的用户名和密码才可以进行访问:

Apache用户认证,域名跳转,Apache访问日志_Apache用户认证_12

Apache用户认证,域名跳转,Apache访问日志_Apache用户认证_13


如果要使用curl命令进行访问的话也可以,需要使用-u选项指定好用户名和密码:

Apache用户认证,域名跳转,Apache访问日志_域名跳转_14

Apache用户认证,域名跳转,Apache访问日志_Apache访问日志_15


我们现在设置的是访问所有的网页文件都需要进行认证,除此之外还可以设置针对单个文件进行认证,只有访问这个文件才需要进行认证,访问其他的文件则不需要进行认证。

Apache用户认证,域名跳转,Apache访问日志_域名跳转_16

  1. 修改一下虚拟主机配置文件,修改成以下内容:

<VirtualHost *:80>

   DocumentRoot "/data/wwwroot/111.com"

   ServerName 111.com

   <FilesMatch 123.php>

       AllowOverride AuthConfig

       AuthName "111.com user auth"

       AuthType Basic

       AuthUserFile /data/.htpasswd

       require valid-user

   </FilesMatch>

</VirtualHost>

Apache用户认证,域名跳转,Apache访问日志_Apache用户认证_17


2.创建123.php文件,用于测试:

vim /data/wwwroot/111.com/123.php

Apache用户认证,域名跳转,Apache访问日志_Apache用户认证_18


  1. 现在可以直接访问111.com:

Apache用户认证,域名跳转,Apache访问日志_Apache用户认证_19


但是如果访问111.com下的123.php就会需要认证了:

Apache用户认证,域名跳转,Apache访问日志_Apache访问日志_20


同样的需要加上用户名和密码验证后才能访问:

Apache用户认证,域名跳转,Apache访问日志_Apache用户认证_21

Apache用户认证,域名跳转,Apache访问日志_Apache用户认证_22











11.19/11.20 域名跳转

Apache用户认证,域名跳转,Apache访问日志_域名跳转_23

域名跳转就是从一个域名跳转到另一个域名上,例如我要访问111.com这个域名,然后加载时会跳转到123.com这个域名上并显示页面内容,这就是域名跳转。

  1. 修改虚拟主机配置文件为以下内容:

<VirtualHost *:80>

   DocumentRoot "/data/wwwroot/www.123.com"

   ServerName www.123.com

   ServerAlias 123.com

   <IfModule mod_rewrite.c> //需要mod_rewrite模块支持

       RewriteEngine on  //打开rewrite功能

       RewriteCond %{HTTP_HOST} !^www.123.com$  //定义rewrite的条件,主机名(域名)不是www.123.com满足条件

       RewriteRule ^/(.*)$ http://www.123.com/$1 [R=301,L] //定义rewrite规则,当满足上面的条件时,这条规则才会执行

</IfModule>

</VirtualHost>

Apache用户认证,域名跳转,Apache访问日志_域名跳转_24


修改完之后重新加载配置文件:

Apache用户认证,域名跳转,Apache访问日志_Apache访问日志_25


在测试之前先检查一下你的apahce是否加载了rewrite模块:

/usr/local/apache2.4/bin/apachectl -M |grep rewrite

Apache用户认证,域名跳转,Apache访问日志_Apache用户认证_26


如果没有加载的话,需要配置一下httpd的配置文件:

Apache用户认证,域名跳转,Apache访问日志_Apache访问日志_27


模块加载了之后就可以进行测试了:

Apache用户认证,域名跳转,Apache访问日志_域名跳转_28


状态码显示301就表示成功:

Apache用户认证,域名跳转,Apache访问日志_Apache访问日志_29

Apache用户认证,域名跳转,Apache访问日志_Apache用户认证_30






11.21 Apache访问日志

Apache用户认证,域名跳转,Apache访问日志_Apache用户认证_31

访问日志记录用户的每一个访问、请求,日志文件在/usr/local/apache2.4/logs/目录下:

Apache用户认证,域名跳转,Apache访问日志_Apache用户认证_32


刚刚我们做实验访问的是111.com,所以日志文件是以111.com开头的,查看日志内容:

Apache用户认证,域名跳转,Apache访问日志_Apache用户认证_33


这个日志是可以定义它的格式的,在apache的主配置文件里定义:

Apache用户认证,域名跳转,Apache访问日志_域名跳转_34

%h 表示来源ip

%l 表示用户

%u也表示用户

%t表示时间

%r表示请求类型(HEAD或GET之类)

%>s 表示状态码

%b 表示大小

%{User-Agent}i 表示用户代理(浏览器或curl就是代理,会显示代理的信息)

%{Referer}i 表示浏览器上一次访问的网址


开始进行配置,将虚拟主机配置文件修改成以下内容:

Apache用户认证,域名跳转,Apache访问日志_Apache用户认证_35


然后使用curl命令和浏览器进行访问一下,然后再查看一下日志文件会发现最新的两行内容格式不一样了:

Apache用户认证,域名跳转,Apache访问日志_Apache访问日志_36




扩展

apache虚拟主机开启php的短标签

http://ask.apelearn.com/question/5370