专栏首页linux运维学习linux学习第三十九篇:Apache用户认证,域名跳转,Apache访问日志

linux学习第三十九篇:Apache用户认证,域名跳转,Apache访问日志

Apache用户认证

  • 虚拟主机的配置文件: vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf 把111.com那个虚拟主机编辑成如下内容
<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>
  • Apache自带命令htpasswd创建密码文件,-c是创建,-m是指定md5加密类型,指定用户为xie(PS:如果再次新增用户,就不需要再加 -c ,因为已经创建过密码文件了): /usr/local/apache2.4/bin/htpasswd -c -m /data/.htpasswd xie
  • 测试语法和加载配置文件: /usr/local/apache2.4/bin/apachectl -t /usr/local/apache2.4/bin/apachectl graceful
  • 再次访问111.com,会出现401状态码,说明访问的这个域名需要用户认证。 curl -x127.0.0.1:80 111.com
  • 重新用浏览器访问111.com网站时就会出现用户认证,用户密码就是刚才增加的用户和设置的密码: PS:记得要在windows上的hosts上添加定义111.com(格式:主机IP 111.com) hosts的路径:C:\Windows\System32\drivers\etc

再次使用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>

修改为如下图所示:

  • 改后记得测试语法,重新加载配置文件以及在/111.com目录创建编辑测试文件123.php: vim /data/wwwroot/111.com/123.php
  • 用curl -x访问: curl -x127.0.0.1:80 111.com -I 不用-u加用户和密码了,也可以访问,出现200状态码 curl -x127.0.0.1:80 111.com/123.php -I 但是访问文件123.php时就出现401了,说明需要用户认证了 curl -x127.0.0.1:80 -uxie:123123 111.com/123.php -I 只有用-u加用户和密码才能正常访问123.php。

域名跳转

  • 把www.example.com域名跳转到111.com,配置如下:
<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> 
  • 查看Apache下有没有加载rewrite模块: /usr/local/apache2/bin/apachectl -M|grep -i rewrite 若无该模块,需要编辑配置文件httpd.conf,删除rewrite_module (shared) 前面的#
  • 用curl访问123.com查看是否会跳转: curl -x127.0.0.1:80 -I www.example.com 状态码为301

Apache访问日志

  • 在主配置文件下搜索LogFormat ,这是Apache的日志格式: vim /usr/local/apache2.4/conf/httpd.conf

User-Agent:用户代理,比如用浏览器或curl访问,那么浏览器或curl就是用户的代理。 Referer:表示打开当前网站的上一个网站的网址。

  • 把虚拟主机配置文件中的common改为combined:
  • 重新加载配置文件 -t,graceful后用浏览器和curl访问111.com,在查看Apache的访问日志,会发现日志的格式改变了(日志的路径:/usr/local/apache2.4/logs/,111.com的路径为:/usr/local/apache2.4/logs/111.com-access_log):

扩展 apache虚拟主机开启php的短标签 http://ask.apelearn.com/question/5370

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • linux学习第四十七篇:Nginx负载均衡,ssl原理,生产ssl密钥对,Nginx配置ssl

    Nginx负载均衡 负载均衡,将用户的所有HTTP请求均衡的分配到每一台机器上,充分发挥所有机器的性能,提高服务的质量和用户体验。 ? vim /usr/l...

    用户1215343
  • linux学习第十三篇:su命令,sudo命令,限制root远程登录

    su命令 su - user1  //彻底切换用户,如果没有加“-”,切换用户不彻底。 su  -c  "touch /tmp/1.txt"  user1   ...

    用户1215343
  • linux学习第六十三篇:Shell脚本介绍,Shell脚本结构和执行,date命令用法,Shell脚本中的变量

    Shell脚本介绍 shell是一种脚本语言 aming_linux blog.lishiming.net 可以使用逻辑判断、循环等语法 可以自定义函数 s...

    用户1215343
  • Web Fundamentsals学习1-Multiple-Screen-Site

    你的一个运行于多设备网站(Your First Multi-device Site) ? 遵循的步骤: 1.定义信息架构(information archite...

    八哥
  • cURL-7.72.0初体验(参数写法)

    这个东西其实就是我现在的写法就是最正宗的写法,就是小写C,大写URL,一定要写对,显得你专业不说,其实更是对软件的一种敬意吧。

    云深无际
  • 干货:4个小技巧助你搞定缺失、混乱的数据(附实例代码)

    导读:数据工作者经常会遇到各种状况,比如你收集到的数据并不像你期待的那样完整、干净。此前我们讲解了用OpenRefine搞定数据清洗,本文进一步探讨用panda...

    华章科技
  • Android自定义一个图形单点移动缩小的效果

    以上所述是小编给大家介绍的Android自定义一个图形单点移动缩小的效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢...

    砸漏
  • 网站跨域的五种解决方式

    等带有src属性的标签可以从不同的域加载和执行资源。其他插件的同源策略:flash、java applet、silverlight、googlegears等浏览...

    yunlgonn
  • 腾讯云发起行业安全把脉行动,直播安全再度成为焦点

    腾讯云安全
  • 教你如何用 RecyclerView 做一个好用的轮播图

    引子 一般情况下,我们手机 App 上轮播图一般都是几张图来回循环,最多也就10几张,一般都是在10张以内的轮播。所以我们一般可能都是自己写,还有可能用到了别人...

    非著名程序员

扫码关注云+社区

领取腾讯云代金券