AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 115827
Accepted
Paul
Paul
Asked: 2010-02-24 07:49:31 +0800 CST2010-02-24 07:49:31 +0800 CST 2010-02-24 07:49:31 +0800 CST

为什么 apache 使用代码 200 记录对 GET http://www.google.com 的请求?

  • 772

最近有人问我“是什么原因导致我们的 access.log 中出现这样的一行?”

59.56.109.181 - - [22/Feb/2010:16:03:35 -0800] “GET http://www.google.com/HTTP/1.1 ” 200 295 “-” “Mozilla/5.0(兼容;MSIE 5.01 ;Win2000)"

我的直接回答是有人在探索一些有点狡猾的东西。

但:

  • 如何?推测... 一个简短的 perl 或 python 脚本可以很容易地连接并请求一个带有无效主机的 URL。
  • 漏洞?当他们这样做时,有人在寻找什么,他们学到了什么,我们应该修补它吗?
  • 我需要一顶锡箔帽来防止他们读懂我的想法吗?
  • 对我来说真正的问题是:不应该是 404 响应,而不是 200!?

这是在标准 LAMP 服务器 (Ubuntu) 上。

linux http apache-2.2 httpd vulnerabilities
  • 3 3 个回答
  • 9281 Views

3 个回答

  • Voted
  1. Best Answer
    Fran tello
    2011-11-17T02:49:56+08:002011-11-17T02:49:56+08:00

    也许你想阅读http://wiki.apache.org/httpd/ProxyAbuse

    特别是这一点:“我的服务器已正确配置为不代理,那么为什么 Apache 返回 200(成功)状态代码?”,它问您的问题“不应该是 404 响应,而不是 200!?”

    如果 apache conf 没问题,它只是发送根页面。这是因为你得到的状态码是 200。

    • 6
  2. sfink
    2010-02-24T09:44:16+08:002010-02-24T09:44:16+08:00

    我认为如果有人试图将服务器用作代理,就会发生这种情况。这将使 http://... URL “正常”(而不是您期望从常规服务器请求中获得的路径部分。)

    至于 200 状态码,那... err.. 好吧,我的服务器也是这样做的。它似乎忽略了http://hostname部分并使用剩余路径从本地服务器返回结果。您可能必须深入研究 RFC 才能弄清楚为什么这样做是有意义的;我不知道答案。

    • 4
  3. Rudy Matela
    2021-03-30T10:59:03+08:002021-03-30T10:59:03+08:00

    假设您没有将服务器用作代理,这些可能是在面向 Internet 的 Web 服务器上经常看到的代理滥用的常见尝试。

    收到状态代码 200 的请求可能会返回您的索引页。您可以使用telnet或进行检查curl。

    假设:

    • 您的服务器名称是site.example.org;

    • 第三方正在尝试连接news.example.net和search.example.com;

    • 您的/index.html文件包含:

        <!DOCTYPE html>
        <html>
        <head><title>It works!</title></head>
        <body><h1>It works!</h1></body>
        </html>
      

    使用curl,您可以重建收到的请求,如下所示:

    $ curl site.example.org --request-target http://news.example.net/
    <!DOCTYPE html>
    <html>
    <head><title>It works!</title></head>
    <body><h1>It works!</h1></body>
    </html>
    

    使用telnet,您可以重建收到的请求,如下所示:

    $ telnet site.example.org 80
    > GET http://news.example.com/ HTTP/1.1
    > Host: news.example.com
    >
    HTTP/1.1 200 OK
    ...
    Content-Type: text/html
    ...
    
    <!DOCTYPE html>
    <html>
    <head><title>It works!</title></head>
    <body><h1>It works!</h1></body>
    </html>
    

    如果您收到您index.html的结果,这意味着您的服务器未配置为代理,您不必担心这些请求。

    如果您实际收到的内容news.example.com或news.example.net 您的 Web 服务器被配置为代理。您可以通过注释proxy on;Nginx 配置中的任何行或禁用mod_proxyApache 配置来停用此功能。

    关于这个的一些有趣的参考:

    • Apache wiki 上的代理滥用
    • 我的 nodejs 日志中出现异常的 GET 请求 - 我的 nginx/node 被黑客入侵了吗?
    • 服务器被探测:为什么我可以看到对其他站点的成功 GET 请求?
    • 1

相关问题

  • 你最喜欢的 Linux 发行版是什么?[关闭]

  • mod_rewrite 不转发 GET 参数

  • 更改 PHP 的默认配置设置?

  • 保护新的 Ubuntu 服务器 [关闭]

  • (软)Ubuntu 7.10 上的 RAID 6,我应该迁移到 8.10 吗?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve