Reverse-Engineering
Veröffentlicht: 2022-03-10Zuletzt aktualisiert am 21. März 2022
Ich werde darüber sprechen, was Reverse Engineering ist und warum es wichtig ist. Viele Leute, die keine Entwickler sind, glauben zu wissen, was Reverse Engineering ist, weil sie es in Filmen gesehen haben, aber das ist ein Missverständnis. Reverse Engineering hat für viele verschiedene Menschen eine Menge Bedeutungen, und was ich Ihnen sagen werde, wird sich sehr von der Definition eines anderen unterscheiden.
Für White-Label-Software bedeutet Reverse Engineering im Wesentlichen, ein Programm zu nehmen und herauszufinden, wie es funktioniert und was es kann. Genauer gesagt nimmt Reverse Engineering ein vorhandenes Programm und lernt seine inneren Abläufe, sodass Sie das Programm so modifizieren können, dass es andere Dinge tut, als der Autor beabsichtigt hat. Sie können mehr darüber erfahren, was White Label bedeutet, wenn Sie auf unserer Website surfen!
In der Softwareentwicklung sagen wir, dass Sie etwas zurückentwickeln, wenn Sie es auseinander nehmen und herausfinden, wie es funktioniert. Reverse Engineering ist vorteilhaft, um zu lernen, wie man die Software benutzt und wie sie funktioniert. Es kann auch für viele verschiedene Dinge wie digitales Marketing, Verteidigung Ihres Unternehmens, Hacking und viele andere Dinge verwendet werden.
Reverse-Engineering im Marketing
Wenn Sie beabsichtigen, eine neue Marketingkampagne zu erstellen, können Sie Software zurückentwickeln, um herauszufinden, was sie tut oder wie sie funktionieren sollte. Anschließend können Sie den Code ändern, um ihn an Ihre Bedürfnisse anzupassen. Sie können dasselbe mit Anzeigen oder anderen Arten von Marketing tun. Es ist auch möglich, Informationen über Wettbewerber, die Spezifikationen und Leistungen eines Produkts und vieles mehr zu erfahren.
Wenn Sie etwas erstellen möchten, müssen Sie zuerst mit einem Design beginnen. Sie können Tools verwenden, die Ihnen bei der Erstellung des Designs helfen, aber Sie sollten es auch mit Ihren Sachen testen, da es wichtig ist zu wissen, ob die Dinge angemessen interagieren. Manchmal müssen Sie in Programmen herumalbern und herausfinden, wie sie funktionieren, indem Sie falsche Ausgaben erstellen. Sie können sogar ein Auto mit einem Bild eines echten Autos fahren, besonders wenn Sie sehen möchten, wie es sich verhält. Wir nennen das virtuelles Fahren oder virtuelles Fahren.
Was ist Reverse-Engineering?
Es ist der Prozess der Analyse eines Computerprogramms, um seine interne Struktur, seinen Quellcode, seine Algorithmen und seinen Datenfluss zu bestimmen. Der Zweck des Reverse Engineering besteht darin, zu verstehen, wie ein Computerprogramm funktioniert und was in dem Programm enthalten ist. Wenn Sie diese Informationen lesen, können sie als Absturzanalyse, Disassemblierung, Reverse Engineering oder Debugging bezeichnet werden. Ich mag „Debuggen“, weil es sich eher wie eine Aktivität anhört, die von einem Programmierer ausgeführt wird, obwohl dies nicht der Fall ist. Heutzutage sind sich die meisten Programmierer nicht einmal bewusst, dass sie Reverse Engineers sind.
Reverse Engineering ist der Prozess, bei dem ein Stück Software, ein Programm (oder Cracker) verwendet wird, um eine Aktion auszuführen, die der Entwickler nie beabsichtigt hatte (aber manchmal vorkommt). In diesem Szenario hat der Hacker einen Codefehler in einem Programm gefunden und herausgefunden, wie er ihn verwenden kann, um den gewünschten Effekt zu erzielen. Hacker haben zum Beispiel Spiele nachgebaut und wissen, wie sie funktionieren oder welche Art von Informationen sie erfahren können.
Warum ist es wichtig?
Fast jede Software auf dem Markt ist rückentwickelt. Es gibt einige Programme, die nicht umgekehrt werden. Sogar die Anwendungen von Microsoft wurden rückentwickelt. Selbst ganze Unternehmen tun nichts anderes, als Software für Geld zurückzuentwickeln.
Reverse Engineering wird immer wichtiger, seit die US-Regierung Gesetze zum Softwareschutz oder Digital Rights Management (DRM) verabschiedet hat. Es gäbe keine Software mit DRM, wenn sie nicht rückentwickelt wäre, und rückentwickelte Programme wären nicht durch DRM geschützt. Es gibt noch mehr Gründe, warum Reverse Engineering wichtig ist, aber das ist ein Thema für ein ganzes Buch (oder eine Reihe von Büchern).
Reverse Engineering hat die Welt verändert. Es hat die Art und Weise, wie die Menschen leben, völlig verändert. Es hat viele Vorteile:
- Sie können Software dazu bringen, das zu tun, was Sie wollen.
- Sie können herausfinden, wie Sie Dinge aus einem Programm entfernen, die nicht dort sein sollten.
- Es wird einfacher, etwas in seine Bestandteile zu zerlegen und weiter zu analysieren.
Was sind Reverse-Engineering-Vorteile?
Sie können sehen, was es tut, und etwas über seine internen Mechanismen erfahren, indem Sie das Programm umkehren. Sie können Änderungen am Programm vornehmen, ohne andere Programme oder das Betriebssystem zu beeinflussen. Dies ist ein erheblicher Vorteil, da die meisten Programme mit Bibliotheken und Betriebssystemen kompatibel sein müssen, die von ihren Herausgebern bereitgestellt werden. Änderungen an einem Programm können nicht nur Ihr System, sondern auch das anderer Benutzer ernsthaft beschädigen. Reverse Engineering gibt Ihnen Zugriff auf alle internen Mechanismen, Bibliotheken und Informationen zur Funktionsweise. Sie können Programme erstellen, die Bibliotheken und Betriebssysteme verwenden können, ohne dafür zu bezahlen.
Was ist der Prozess des Reverse Engineering?
Dies ist eine komplizierte Frage, da die Antwort von Ihrem Reverse-Engineering-Programm abhängt. Die beste Antwort, die ich Ihnen geben kann, ist: „Es kommt darauf an…“. Moderne Programme verfügen über Anti-Debugging, Anti-Reverse-Engineering und Anti-Overwriting-Code. Dies bedeutet, dass Reverse Engineering eine starke Verschleierung erfordert, die Zeit verschwendet und manchmal zu Programmabstürzen führen kann.
Verschleierung ist eine Anti-Reverse-Engineering-Technik, die das Reverse-Engineering des Programms erschwert. Subroutinen, Funktionen und andere Teile eines Programms werden normalerweise an andere Stellen im Speicher verschoben, und Datenstrukturen werden mit magischen Zahlen geändert. Manchmal wird der Code verschlüsselt oder nach bestimmten Wörtern durchsucht, die Aufschluss über seine Struktur geben könnten. Dies reicht nicht immer aus, um Reverse Engineers zu besiegen, daher stürzt ein Programm manchmal ab, wenn versucht wird, es mit bestimmten Tools zu disassemblieren. In vielen Ländern ist es illegal, selbst wenn Sie eine Kopie der Software besitzen und sie in keiner Weise modifiziert haben.
Wie kann man Software/Programme zurückentwickeln?
Wenn Sie es nicht gewohnt sind, Engineering-Software umzukehren, ist es ratsam, zuerst mit barrierefreien Programmen zu beginnen. Es wäre am besten, wenn Sie versuchen, Reverse-Engineering-spezifische Tools zu lernen, bevor Sie ins kalte Wasser springen. Ein gutes Tool für Einsteiger ist IDA Pro. (IDA steht für Intrusion Detection Analysis). Es ist kostenlos, leicht zugänglich und kann fast jedes Programm umkehren, solange es 32-Bit ist. IDA Pro analysiert kompilierten oder disassemblierten Code und zeigt ihn dann so an, dass er für Sie einfacher zu lesen, zu verstehen und sogar zu bearbeiten ist. IDA Pro ist ein gutes Werkzeug für einen Reverse Engineer, aber es ist nicht für alle Situationen geeignet.
Ein weiteres Tool ist GDB, ein Debugging-Tool wie Visual Studio. GDB debuggt den Code jedoch während der Ausführung, genau wie Visual Studio. Der Unterschied besteht darin, dass Sie während der Ausführung Änderungen am Code vornehmen und dann einen Programmabsturz verursachen können. Dadurch können Sie den Fehler in der Logik sehen (vorausgesetzt, ein Anti-Debugging-/Anti-Reverse-Engineering-Mechanismus maskiert ihn nicht). Danach können Sie den Fehler beheben oder die Ausführung fortsetzen, bis ein anderer Teil des Programms ein Problem verursacht.
Was sind die Risiken des Reverse Engineering?
In den meisten Ländern ist es illegal, Software zurückzuentwickeln. Es ist jedoch in einigen Situationen in den USA nicht illegal, solange Sie eine Kopie des Programms besitzen und nachweisen können, dass es legal erworben wurde (unter Verwendung einer Seriennummer oder eines CD-Schlüssels). Es gibt auch Ausnahmen für Antikopier- und Antipirateriemechanismen, die nur für Bildungszwecke zulässig sind. Um ein Programm zurückzuentwickeln, müssen Sie über genügend Informationen verfügen. Dies bedeutet normalerweise, dass Sie den Quellcode des Programms verstehen, das Sie zurückentwickeln. Es ist nicht immer einfach, selbst wenn Sie den Quellcode lesen können, vor allem, wenn ein Anti-Debugging-/Anti-Reverse-Engineering-Mechanismus verwendet wurde.
Ich hoffe, Sie haben eine bessere Vorstellung davon, was Reverse Engineering bedeutet und wie man es auf verschiedene Fälle anwendet. Ich hoffe auch, dass Sie sich in diesem Bereich besser auskennen und Ihrem Unternehmen und Ihren Kunden helfen, mit ihren Wissenswerkzeugen auf modernere Weise zu wachsen.