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

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
日志服务 SLS,月写入数据量 50GB 1个月
.cn 域名,1个 12个月
简介:

httpd的用户认证

注意: 本章使用浏览器进行检测的前提是在物理机hosts文件添加虚拟机IP和虚拟主机域名。

配置用户认证

  • 编辑httpd配置文件/usr/local/apache2.4/conf/httpd.conf

    [root@localhost ~]# vim /usr/local/apache2.4/conf/httpd.conf
    <Directory "/usr/local/apache2.4/htdocs/">
    ......
    #将AllowOverride后面的None改成AuthConfig
    #AllowOverride None
    #添加下面几行内容:
    Allowoverride AuthConfig
    #打开用户认证的开关
    AuthName "111.com user auth"
    #登录时提示内容,作用不大
    AuthType Basic
    #认证方式,一般为Basic
    AuthUserFile /data/.htpasswd
    #指定密码文件的位置(密码文件需手动添加)
    require valid-user
    #设定需要认证的用户,valid-user为“AuthUserFile”中定义的所有用户
    </Directory>

  • 创建httpd.conf 中指定的密码文件

    [root@localhost ~]# /usr/local/apache2.4/bin/htpasswd -c -m /data/.htpasswd huang 
    New password: 
    Re-type new password: 
    Adding password for user huang
    [root@localhost ~]# cat /data/.htpasswd 
    huang:$apr1$4M2zku4l$pny2EUPn6ouM7wjqHCaj.0

    -c创建文件,-m使用md5加密。只有在第一次创建文件时才使用-c参数。创建其它用户也要通过htpasswd命令创建。

  • 配置完成后重新加载

    [root@localhost ~]# /usr/local/apache2.4/bin/apachectl -t
    Syntax OK
    [root@localhost ~]# /usr/local/apache2.4/bin/apachectl graceful

  • 测试

    [root@localhost ~]# curl -x192.168.159.128:80 111.com -I
    HTTP/1.1 401 Unauthorized
    Date: Wed, 20 Dec 2017 07:33:15 GMT
    Server: Apache/2.4.29 (Unix) PHP/7.1.6
    WWW-Authenticate: Basic realm="111.com user auth"
    Content-Type: text/html; charset=iso-8859-1

    提示状态码为“401”,说明当前访问的内容需要进行用户认证。111.com为任意地址,因为配置文件中SeverName www.example.com:80。

    使用用户名和密码访问:
    [root@localhost ~]# curl -x192.168.159.128:80 -uhuang:159820 111.com -I
    HTTP/1.1 200 OK
    Date: Wed, 20 Dec 2017 08:53:27 GMT
    Server: Apache/2.4.29 (Unix) PHP/7.1.6
    Last-Modified: Mon, 11 Jun 2007 18:53:14 GMT
    ETag: "2d-432a5e4a73a80"
    Accept-Ranges: bytes
    Content-Length: 45
    Content-Type: text/html

    状态码为200,访问成功。其中用户名密码格式为 -u用户名:密码。

用浏览器测试:访问地址,会提示输入账号密码。输入账号密码后即可访问。

  • htppasswd命令

    htpasswd命令是Apache的Web服务器内置工具,用于创建和更新储存用户名、域和用户基本认证的密码文件。

参数:

-c:=create,创建一个加密文件

-n:不更新加密文件,只将更新后的用户名密码显示在屏幕上

-m:使用MD5算法对密码进行加密(默认)

-d:使用CRYPT算法对密码进行加密

-p:不对密码进行加密,即明文密码

-s:使用SHA算法对密码进行加密

-b:在命令行一并输入用户名和密码,而不是根据提示输入密码

-D:删除指定用户

对网站中指定文件设置用户认证

  • 编辑httpd配置文件/usr/local/apache2.4/conf/httpd.conf

    [root@localhost ~]# vim /usr/local/apache2.4/conf/httpd.conf
    <FilesMatch 1.php>

    Allowoverride AuthConfig

    AuthName "111.com user auth"
    AuthType Basic
    AuthUserFile /data/.htpasswd
    require valid-user
    </FilesMatch>

    添加上面内容。

  • 配置完重新加载

    [root@localhost ~]# /usr/local/apache2.4/bin/apachectl -t
    Syntax OK
    [root@localhost ~]# /usr/local/apache2.4/bin/apachectl graceful

  • 检测

    可以访问111.com
    [root@localhost ~]# curl -x192.168.159.128:80 111.com
    <html><body><h1>It works!</h1></body></html>
    不可以访问111.com/1.php,代码401,1.php需要用户名密码才能访问。
    [root@localhost ~]# curl -x192.168.159.128:80 111.com/1.php -I
    HTTP/1.1 401 Unauthorized
    Date: Wed, 20 Dec 2017 09:24:52 GMT
    Server: Apache/2.4.29 (Unix) PHP/7.1.6
    WWW-Authenticate: Basic realm="111.com user auth"
    Content-Type: text/html; charset=iso-8859-1
    使用用户名密码正常访问111.com/1.php
    [root@localhost ~]# curl -x192.168.159.128:80 -uhuang:159820 111.com/1.php -I
    HTTP/1.1 200 OK
    Date: Wed, 20 Dec 2017 09:25:03 GMT
    Server: Apache/2.4.29 (Unix) PHP/7.1.6
    X-Powered-By: PHP/7.1.6
    Content-Type: text/html; charset=UTF-8

用浏览器测试,能直接访问111.com。访问111.com/1.php需要用户名和密码。

对httpd虚拟主机设置用户认证

  • 编辑虚拟主机配置文件 /usr/local/apache2.4/conf/extra/httpd-vhosts.conf

    localhost ~]# vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf
    添加下面内容:
    <Directory /usr/local/apache2.4/htdocs>
    AllowOverride AuthConfig
    #打开用户认证的开关
    AuthName "wellcome"
    #登录时提示内容,作用不大
    AuthType Basic
    #认证方式,一般为Basic
    AuthUserFile /data/.htpasswd
    #指定密码文件的位置(密码文件需手动添加)
    require valid-user
    #设定需要认证的用户,valid-user为“AuthUserFile”中定义的所有用户
    </Directory>

配置完成后检测更新配置。访问111.com和111.com/1.php都需要密码。

  • 指定文件设置用户配置

    localhost ~]# vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf
    添加下面内容:
    <FilesMatch 1.php> 
    AllowOverride AuthConfig
    #打开用户认证的开关
    AuthName "wellcome"
    #登录时提示内容,作用不大
    AuthType Basic
    #认证方式,一般为Basic
    AuthUserFile /data/.htpasswd
    #指定密码文件的位置(密码文件需手动添加)
    require valid-user
    #设定需要认证的用户,valid-user为“AuthUserFile”中定义的所有用户
    </FilesMatch>

    配置完成后检测更新配置。访问111.com不需要密码,访问111.com/1.php需要密码。

注意: apache虚拟主机中,第一个配置为默认虚拟主机。当为第二个虚拟主机配置用户认证后,访问时不能直接访问ip,需要访问ServerName 地址。

域名跳转

域名跳转分类及区别:

种类:301表示永久跳转;302表示临时跳转。

区别:

  • 使用效果不同

    302跳转是暂时的跳转,搜索引擎会抓取新的内容而保留旧的网址。因为服务器返回302代码,搜索引擎认为新的网址只是暂时的。
    301重定向是永久的重定向,搜索引擎在抓取新内容的同时也将旧的网址替换为重定向之后的网址。

  • SEO使用方式不同

    在搜索引擎优化中302跳转被众多黑帽SEO优化人员追求,对网站进行恶意302跳转至非用户目标访问网站,因此搜索引擎对于网站的302跳转通常是比较不友好,所以要慎用302跳转!

SEO

SEO(Search Engine Optimization)搜索引擎优化,在了解搜索引擎自然排名机制的基础上,对网站进行内部及外部的调整优化,改进网站在搜索引擎中的关键词自然排名,获得更多流量,从而达成网站销售及品牌建设的预期目标

域名跳转配置

  • 配置虚拟主机配置文件:/usr/local/apache2.4/conf/extra/httpd-vhosts.conf

    [root@localhost ~]# vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf
    ……
    添加下面这些代码:
    <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$
    #Cond=condition,定义rewrite条件:所有非111.com的主机名(域名)
    RewriteRule ^/(.
    )$ http://111.com/$1 [R=301,L]
    #定义rewrite规则:当满足上面条件时才执行当前规则,即跳转到111.com。
    </IfModule>

  • 检查系统配置

    [root@localhost ~]# /usr/local/apache2.4/bin/apachectl -t
    Syntax OK
    [root@localhost ~]# /usr/local/apache2.4/bin/apachectl graceful
    检查apache是否加载了虚拟主机中调用的rewrite模块:
    [root@localhost ~]# /usr/local/apache2.4/bin/apachectl -M | grep rewrite

rewrite模块再apache配置文件httpd.conf中配置

[root@adailinux ~]# vim /usr/local/apache2.4/conf/httpd.conf   
……
LoadModule rewrite_module modules/mod_rewrite.so
#取消注释即可
LoadModule php5_module        modules/libphp5.so
#LoadModule php7_module        modules/libphp7.so

修改完配置文件需要重新检测、刷新。

  • 使curl命令检测

    [root@adailinux ~]# curl -x192.168.8.131:80 www.example.com -I
    HTTP/1.1 301 Moved Permanently
    Date: Mon, 31 Jul 2017 07:17:37 GMT
    Server: Apache/2.4.27 (Unix) PHP/5.6.30
    Location: http://111.com/
    Content-Type: text/html; charset=iso-8859-1

    此时,状态码为301,即设定了域名永久跳转!

在浏览器进行检测时,访问“www.example.com”会直接跳转到“111.com”。

Apache 访问日志

每一次访问请求都会记录在日志中

  • apache访问日志的目录为/usr/local/apache2.4/logs/

    [root@localhost ~]# ls /usr/local/apache2.4/logs/
    111.com-access_log 111.com-error_log abc.com-access_log abc.com-error_log access_log error_log httpd.pid

日志目录下有每个虚拟主机的日志文件

  • 自定义日志格式

    系统自带两种日志格式:combine和common,默认使用common模式。

    LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined
    LogFormat "%h %l %u %t \"%r\" %>s %b" common
    #h表示host来源IP
    #l表示login用户
    #u表示user用户名密码
    #t表示time时间,
    #r表示request行为(curl时,加I为head,不加Iget)
    #s表示status状态码,b表示byte大小
    #user-agent:用户代理(使用什么方式访问,浏览器或者curl命令或者其它)
    #referer:跳转到当前位置的上一个网址(即:提供当前IP的网站)

  • 配置日志格式

    编辑虚拟主机配置文件httpd-vhosts.conf

    [root@localhost ~]# vim /usr/local/apache2.4/conf/extra/httpd-vhosts.conf 
    <VirtualHost *:80>
    ...
    ErrorLog "logs/111.com-error_log"
    CustomLog "logs/111.com-access_log" combined
    ...

    将日志文件路径后面的common改为combined

  • 测试并重新加载

    [root@localhost ~]# /usr/local/apache2.4/bin/apachectl -t
    Syntax OK
    [root@localhost ~]# /usr/local/apache2.4/bin/apachectl graceful

可以通过cat、tail等命令查看日志,tail -f可以查看动态的日志。



本文转自 豆渣锅 51CTO博客,原文链接:http://blog.51cto.com/754599082/2052735

相关文章
|
3月前
|
存储 消息中间件 Java
Apache Flink 实践问题之原生TM UI日志问题如何解决
Apache Flink 实践问题之原生TM UI日志问题如何解决
46 1
|
3月前
|
域名解析 网络协议 安全
在Linux中,想在命令行下访问某个网站,并且该网站域名还没有解析,如何做?
在Linux中,想在命令行下访问某个网站,并且该网站域名还没有解析,如何做?
|
3月前
|
运维 Serverless 网络安全
函数计算产品使用问题之通过仓库导入应用时无法配置域名外网访问,该如何排查
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
25天前
|
域名解析 网络协议 前端开发
浏览器输入域名网址访问后的过程详解
1、以91处理网为例,客户端浏览器通过DNS解析到www.91chuli.com,IP地址是202.108.22.5,通过这个IP地址找到客户端到服务器的路径。客户端浏览器发起一个HTTP会话到202.108.22.5,然后通过TCP进行封装数据包,输入到网络层。
33 2
|
1月前
|
存储 Kubernetes 负载均衡
基于Ubuntu-22.04安装K8s-v1.28.2实验(四)使用域名访问网站应用
基于Ubuntu-22.04安装K8s-v1.28.2实验(四)使用域名访问网站应用
30 1
|
1月前
|
域名解析 缓存 网络协议
Windows系统云服务器自定义域名解析导致网站无法访问怎么解决?
Windows系统云服务器自定义域名解析导致网站无法访问怎么解决?
|
2月前
|
网络协议 开发工具 git
hexo github部署,通过域名访问你的博客
本文介绍了如何使用Hexo命令部署博客到GitHub,并详细说明了如何通过自定义域名访问GitHub上部署的博客。
hexo github部署,通过域名访问你的博客
|
3月前
|
存储 消息中间件 人工智能
AI大模型独角兽 MiniMax 基于阿里云数据库 SelectDB 版内核 Apache Doris 升级日志系统,PB 数据秒级查询响应
早期 MiniMax 基于 Grafana Loki 构建了日志系统,在资源消耗、写入性能及系统稳定性上都面临巨大的挑战。为此 MiniMax 开始寻找全新的日志系统方案,并基于阿里云数据库 SelectDB 版内核 Apache Doris 升级了日志系统,新系统已接入 MiniMax 内部所有业务线日志数据,数据规模为 PB 级, 整体可用性达到 99.9% 以上,10 亿级日志数据的检索速度可实现秒级响应。
AI大模型独角兽 MiniMax 基于阿里云数据库 SelectDB 版内核 Apache Doris 升级日志系统,PB 数据秒级查询响应
|
2月前
|
PHP
ThinkPHP 多应用配置,及不同域名访问不同应用的配置【详解】
本文详解了在ThinkPHP框架中配置多应用的方法,包括安装扩展、删除默认controller文件夹、创建多应用、修改配置文件以启用多应用、测试访问以及如何配置不同域名访问不同应用的步骤。
ThinkPHP 多应用配置,及不同域名访问不同应用的配置【详解】
|
3月前
|
负载均衡 应用服务中间件 nginx
搭建域名访问环境二(负载均衡到网关)
这篇文章讲述了如何配置Nginx实现域名访问环境,通过负载均衡将请求从Nginx反向代理到服务网关,并提供了详细的配置步骤和测试验证方法。
搭建域名访问环境二(负载均衡到网关)

推荐镜像

更多
下一篇
无影云桌面