Smali - Decompiling/[Modifying]/Compiling
Last updated
Last updated
Learn & practice AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE) Learn & practice GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
Deepen your expertise in Mobile Security with 8kSec Academy. Master iOS and Android security through our self-paced courses and get certified:
Czasami interesujące jest modyfikowanie kodu aplikacji, aby uzyskać dostęp do ukrytych informacji (może dobrze z obfuskowanymi hasłami lub flagami). Wtedy może być interesujące, aby zdekompilować apk, zmodyfikować kod i ponownie go skompilować.
Opcodes reference: http://pallergabor.uw.hu/androidblog/dalvik_opcodes.html
Using Visual Studio Code and the APKLab extension, you can automatically decompile, modify, recompile, sign & install the application without executing any command.
Inny skrypt, który bardzo ułatwia to zadanie, to https://github.com/ax/apk.sh
Using APKTool you can access to the smali code and resources:
Jeśli apktool zgłasza jakikolwiek błąd, spróbuj zainstalować najowszą wersję
Niektóre interesujące pliki, które powinieneś sprawdzić to:
res/values/strings.xml (i wszystkie xml w res/values/*)
AndroidManifest.xml
Każdy plik z rozszerzeniem .sqlite lub .db
Jeśli apktool
ma problemy z dekodowaniem aplikacji, sprawdź https://ibotpeaches.github.io/Apktool/documentation/#framework-files lub spróbuj użyć argumentu -r
(Nie dekoduj zasobów). Wtedy, jeśli problem był w zasobie, a nie w kodzie źródłowym, nie będziesz miał problemu (nie zdekodujesz również zasobów).
Możesz zmienić instrukcje, zmienić wartość niektórych zmiennych lub dodać nowe instrukcje. Zmieniam kod Smali używając VS Code, następnie instalujesz rozszerzenie smalise, a edytor powie ci, czy jakakolwiek instrukcja jest niepoprawna. Niektóre przykłady można znaleźć tutaj:
Lub możesz sprawdzić poniżej niektóre zmiany Smali wyjaśnione.
Po modyfikacji kodu możesz przeładować kod używając:
To skompilować nowy APK w folderze dist.
Jeśli apktool zgłosi błąd, spróbuj zainstalować najowszą wersję
Następnie musisz wygenerować klucz (zostaniesz poproszony o hasło i o kilka informacji, które możesz wypełnić losowo):
Finally, podpisz nowy APK:
zipalign to narzędzie do wyrównywania archiwów, które zapewnia ważne optymalizacje plików aplikacji Android (APK). Więcej informacji tutaj.
Jeśli wolisz używać apksigner zamiast jarsigner, musisz podpisać apk po zastosowaniu optymalizacji z zipalign. ALE ZWRÓĆ UWAGĘ, ŻE MUSISZ PODPISAĆ APLIKACJĘ TYLKO RAZ Z jarsigner (przed zipalign) LUB Z aspsigner (po zipalign).
Dla poniższego kodu Java Hello World:
Kod Smali będzie:
Zestaw instrukcji Smali jest dostępny tutaj.
Niektóre zmienne są definiowane na początku funkcji za pomocą opkodu const, możesz modyfikować ich wartości lub możesz zdefiniować nowe:
Recommendations:
Jeśli zamierzasz używać zadeklarowanych zmiennych wewnątrz funkcji (zadeklarowane v0,v1,v2...) umieść te linie pomiędzy .local <number> a deklaracjami zmiennych (const v0, 0x1)
Jeśli chcesz umieścić kod logowania w środku kodu funkcji:
Dodaj 2 do liczby zadeklarowanych zmiennych: Przykład: z .locals 10 do .locals 12
Nowe zmienne powinny być następnymi numerami już zadeklarowanych zmiennych (w tym przykładzie powinny być v10 i v11, pamiętaj, że zaczyna się od v0).
Zmień kod funkcji logowania i użyj v10 i v11 zamiast v5 i v1.
Pamiętaj, aby dodać 3 do liczby .locals na początku funkcji.
Ten kod jest przygotowany do wstawienia w środku funkcji (zmień numer zmiennych w razie potrzeby). Weźmie wartość this.o, przekształci ją na String i następnie wykona toast z jej wartością.
Zgłębiaj swoją wiedzę w zakresie Bezpieczeństwa Mobilnego z 8kSec Academy. Opanuj bezpieczeństwo iOS i Androida dzięki naszym kursom w trybie samodzielnym i zdobądź certyfikat:
Ucz się i ćwicz Hacking AWS:HackTricks Training AWS Red Team Expert (ARTE) Ucz się i ćwicz Hacking GCP: HackTricks Training GCP Red Team Expert (GRTE)