【vulhub】CVE-2018-8715 AppWeb认证绕过漏洞

漏洞描述

1. 漏洞编号:CVE-2018-8715

2. 影响版本:Appweb < 7.0.3

3. 漏洞产生原因:

AppWeb简介:

AppWeb是Embedthis Software LLC公司负责开发维护的一个基于GPL开源协议的嵌入式Web Server。他使用C/C++来编写,能够运行在几乎先进所有流行的操作系统上。当然他最主要的应用场景还是为嵌入式设备提供Web Application容器。

AppWeb可以进行认证配置,其认证方式包括以下三种:

  • 1.basic 传统HTTP基础认证
  • 2.digest 改进版HTTP基础认证,认证成功后将使用Cookie来保存状态,而不用再传递Authorization头
  • 3.form 表单认证

漏洞描述:

其7.0.3之前的版本中,对于digest和form两种认证方式,如果用户传入的密码为null(也就是没有传递密码参数),appweb将因为一个逻辑错误导致直接认证成功,并返回session。

详见:SSD Advisory - AppWeb Authentication Bypass (Digest, and Basic) - SSD Secure Disclosure

漏洞复现

启动环境

docker-compose build
docker-compose up -d

环境启动后,访问http://your-ip:8080即可查看首页

 

利用该漏洞需要知道一个已存在的用户名,当前环境下用户名为admin

(1)刷新网页并抓包,加入构造好的参数Authorization: Digest username=admin,并发送数据包:

 

可见,因为我们没有传入密码字段,所以服务端出现错误,直接返回了200,且包含一个session

(2)利用获取到的 session
修改请求头为POST 添加 session 请求体(或者在浏览器中设置得到的session),便可以成功绕过认证

 

 修复方案

打补丁,升级到最新版本~

 

posted @ 2025-05-17 18:43  Antoniiiia  阅读(44)  评论(0)    收藏  举报