Heim > Backend-Entwicklung > PHP-Tutorial > Schritt-für-Schritt-Praktische Methode zur Wiederherstellung PHP-verschlüsselter Dateien

Schritt-für-Schritt-Praktische Methode zur Wiederherstellung PHP-verschlüsselter Dateien

藏色散人
Freigeben: 2023-04-09 19:38:02
nach vorne
3616 Leute haben es durchsucht

ps: Der Autor dient nur der technischen Kommunikation und hat keine böswilligen Absichten. Bitte missbrauchen Sie diese Technologie nicht.

Praktische Wiederherstellung von PHP-verschlüsselten Dateien

Lassen Sie uns zuerst über die Umgebung sprechen:

    Ubuntu 14.04.4 LTS (GNU/Linux 3.13.0-52-generic x86_64)
    PHP 5.5.9-1ubuntu4.19 (cli)
Nach dem Login kopieren

Praktischer Prozess

Ich habe ein verschlüsseltes Projekt und eine PHP-erweiterte dynamische Linkbibliothek (jinhou.so) zur Hand.

Der PHP-Code sieht wie folgt aus:

<?php /* xxxx技术有限公司版权所有: 2016-09-08 08:18:00 */
jhgo(&#39;uGpqefbDEBkqp4preQ2UaAp3RAUeJAZ5s4aERAQMkxbJTgEovHnQw6WxsA99sAhSacJCLGxZL4Q4u6zFyGveuDUoemktHGkMaB5D&#39;);
?>
Nach dem Login kopieren

Gemäß den oben analysierten bekannten Bedingungen:

1 Die Verschlüsselungsmethode ähnelt der Eval-Verschlüsselungsmethode.

2.jhgo enthält Ausführungscode und Entschlüsselungscode.

3.jinhou.so enthält die jhgo-Funktion.

Verwenden Sie zunächst VIM, um jinhou.so sehr grob zu öffnen, um festzustellen, ob wichtige Informationen vorhanden sind.

Schritt-für-Schritt-Praktische Methode zur Wiederherstellung PHP-verschlüsselter Dateien

Leider ist die Quelle der Lösung eindeutig angegeben. https://github.com/eixom/zoeeyguard

Nachdem wir uns den Code angesehen haben, stellt diese Erweiterung theoretisch zwei Methoden offen, eine zum Verschlüsseln von Dateien und eine zum Entschlüsseln von Dateien. Aber nur eine Methode wurde tatsächlich offengelegt, und eine davon wurde vom gerissenen Anbieter entfernt.

Natürlich haben wir den Quellcode bereits, daher kümmern wir uns nicht so sehr darum.

Ich habe versucht, es mit dem offiziellen Quellcode zu kompilieren und es dann zu dekodieren, und festgestellt, dass es immer noch nicht funktioniert.

Nachdem ich es sorgfältig studiert hatte, stellte ich fest, dass

Schritt-für-Schritt-Praktische Methode zur Wiederherstellung PHP-verschlüsselter Dateien

eine sehr magische Zeichenfolge enthielt: 82dsa7dsas32112389uy7aydh8h2h2i412 Ich fragte mich, ob es sein Verschlüsselungsschlüssel war. Nach erneutem Lesen des Codes stellte sich heraus, dass er wahr war. In der Datei https://github.com/eixom/zoeeyguard/blob/master/src/guard.h. 82dsa7dsas32112389uy7aydh8h2h2i412 心想是不是他的加密Key。再翻代码果真是。在 https://github.com/eixom/zoeeyguard/blob/master/src/guard.h 文件里面。
原来的是 28dsa7dsas12312389uy7aydh8h1h2i312Das Original ist 28dsa7dsas12312389uy7aydh8h1h2i312. Nachdem ich die Änderungen vorgenommen hatte, stellte ich fest, dass es immer noch nicht funktionierte.

Wie erwartet bin ich immer noch Too Young Too Simple.

Analyse aus der psychologischen Perspektive von Programmierern: Im Allgemeinen ändert niemand den Code, sondern im Grunde nur die Parameter. Gibt es weitere Parameter, die geändert wurden? Aber andere Parameter liegen im Array-Format vor, was Kopfschmerzen bereitet.

/*  private key */
#define PRIVATE_KEY "28dsa7dsas12312389uy7aydh8h1h2i312"
#define PRIVATE_KEY_LEN sizeof(PRIVATE_KEY)

/* order */
static const unsigned char OBFUSCATED_ORDER[] = {
      13,  6,  5,  7,  1, 15, 14, 20
    ,  9, 16, 19,  4, 18, 10,  2,  8
    , 12,  3, 11,  0, 17
};
#define ORDER_SIZE sizeof(OBFUSCATED_ORDER) / sizeof(* OBFUSCATED_ORDER)

/* alphabet for base64 */
static const unsigned char OBFUSCATED_ALPHABET[] = {
      's', '4', 'N', 'E', 'k', 'X', 'c', 'u'
    , 'J', '2', 'U', 'o', 'O', 'w', 'K', 'v'
    , 'h', 'H', 'C', '/', 'D', 'q', 'l', 'R'
    , 'B', 'r', '5', 'Z', 'S', 'Q', '6', 'W'
    , '3', 'L', 'j', '8', '1', 'z', '0', 'G'
    , 'n', 'e', 'y', 'b', 'I', 'd', 'i', 'P'
    , 'A', '9', '7', '+', 'm', 'V', 'M', 'Y'
    , 'F', 'g', 'f', 'p', 'a', 'T', 't', 'x'
};
#define ALPHABET_SIZE 64
Nach dem Login kopieren

Dies ist die Zeit, ein Killer-Tool herauszubringen: IDA Pro v6.8, ein Dekompilierungsartefakt. Die linke Seite ist die normale Version und die rechte Seite ist jinhou.so.

Schritt-für-Schritt-Praktische Methode zur Wiederherstellung PHP-verschlüsselter Dateien

Ändern Sie die Dateien in Guard.h basierend auf den Daten. Nach der Neukompilierung wurde es erfolgreich entschlüsselt.

<?php require_cache(APP_PATH.&#39;/Lib/Action/User/AddonAction.class.php&#39;);
?>
Nach dem Login kopieren

Zusammenfassung danach

1 Das Knacken dauerte nicht lange, vor allem dank der Tatsache, dass uns das Verschlüsselungsschema und der Verschlüsselungscode klar mitgeteilt wurden.
2. Die Hauptzeit besteht darin, die Verschlüsselungsparameter zu testen. Glücklicherweise ist die .so-Datei nicht gepackt.
3. Während des Cracking-Prozesses erfuhr ich auch von den Mängeln der PHP-Verschlüsselung.

【Empfohlenes Lernen: PHP-Video-Tutorial

Das obige ist der detaillierte Inhalt vonSchritt-für-Schritt-Praktische Methode zur Wiederherstellung PHP-verschlüsselter Dateien. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
php
Quelle:segmentfault.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Aktuelle Ausgaben
PHP-Datenerfassung?
Aus 1970-01-01 08:00:00
0
0
0
PHP-Erweiterung intl
Aus 1970-01-01 08:00:00
0
0
0
Wie man PHP gut lernt
Aus 1970-01-01 08:00:00
0
0
0
Mehrere PHP-Versionen
Aus 1970-01-01 08:00:00
0
0
0
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage