<?xml version="1.0" encoding="utf-8" standalone="no"?><manifestxmlns:android="http://schemas.android.com/apk/res/android" <!-- The package name, which is the unique identifier for the app in the Android ecosystem. --> package="com.example.app"<!-- The version of the Android SDK used to compile the app. --> android:compileSdkVersion="34"<!-- The codename for the compile SDK version (e.g., "14" for Android 14). --> android:compileSdkVersionCodename="14"<!-- The internal version code of the platform used to build the app. --> platformBuildVersionCode="34"<!-- The version name of the platform used to build the app, corresponding to the codename of the Android version. --> platformBuildVersionName="14"><!-- Permissions required by the app --> <uses-permissionandroid:name="android.permission.INTERNET" /> <uses-permissionandroid:name="android.permission.ACCESS_FINE_LOCATION" /> <uses-permissionandroid:name="android.permission.READ_EXTERNAL_STORAGE" /><!-- Declaring minimum and target SDK versions --> <uses-sdkandroid:minSdkVersion="29"android:targetSdkVersion="34" /><!-- Declaring features required by the app --> <uses-featureandroid:name="android.hardware.camera"android:required="true" /> <uses-featureandroid:name="android.hardware.location.gps"android:required="false" /><!-- Main application block --> <applicationandroid:allowBackup="true"android:icon="@mipmap/ic_launcher"android:label="@string/app_name"android:networkSecurityConfig="@xml/network_security_config"android:theme="@style/AppTheme"><!-- Main launcher activity --> <activityandroid:name=".MainActivity"> <intent-filter> <actionandroid:name="android.intent.action.MAIN" /> <categoryandroid:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity><!-- Another activity with an intent filter --> <activityandroid:name=".DeepLinkActivity"android:exported="true"> <intent-filter> <actionandroid:name="android.intent.action.VIEW" /> <categoryandroid:name="android.intent.category.DEFAULT" /> <categoryandroid:name="android.intent.category.BROWSABLE" /> <dataandroid:scheme="https"android:host="www.example.com"android:pathPrefix="/deeplink" /> </intent-filter> </activity><!-- Service example --> <serviceandroid:name=".MyService"android:enabled="true"android:exported="false"> </service><!-- Broadcast receiver example --> <receiverandroid:name=".MyBroadcastReceiver"android:exported="true"> <intent-filter> <actionandroid:name="android.intent.action.BOOT_COMPLETED" /> </intent-filter> </receiver><!-- Content provider example --> <providerandroid:name=".MyContentProvider"android:authorities="com.example.app.provider"android:enabled="true"android:exported="true" /><!-- Meta-data example --> <meta-dataandroid:name="com.google.android.geo.API_KEY"android:value="your_google_maps_api_key_here" /> </application></manifest>
aapt utility
Dump all permissions
aaptdumppermissionsapp.apk
Dump all strings
aaptdumpstringsapp.apk
Dump all intent-filters
NOTE: Make you sure file AndroidManifest.xml is in the same directory as you execute aapt when dump data from any AndroidManifest.xml.
- "adb devices": - "Show connected devices"- "adb root": - "Get a root shell - Works only on certain images. Example: LineageOS."- "adb reboot bootloader": - "Reboot the device into the boot loader mode"- "adb shell install -r": - "Install a new package (overwrite existing one)"- "adb push <local> <remote>": - "Upload a file from the laptop to the phone"- "adb pull <remote> <local>": - "Download a file from the phone to the laptop"- "adb shell dumpsys iphonesybinfo": - "Get the IMEI"- "adb get-serialno": - "Serial number of the device"- "adb shell pm list features": - "List the features of the smartphone"- "adb shell screencap -p \"/Path/To/Save/Image.png\"": - "Take a screenshot"- "adb shell screen record \"/Path/CaptureRecord.mp4\"": - "Capture a video of the device screen"- "adb shell am start -W -c android.intent.category.HOME -a android.intent.action.MAIN": - "Simulating pressing the Home Button"- "adb shell am start|startservice|broadcast <INTENT>": - "Start an Intent / service / broadcast receiver"- "adb logcat": - "System log information"- "adb bugreport": - "Dump the whole device information like dumpstate, dumpsys and logcat output. Important to get the Bluetooth Low Energy log!"- "adb backup": - "Backup all applications that have the 'backup=true' in their Manifest.xml"- "fastboot devices": - "List available devices in fastboot mode"- "adb shell pm reset-permissions -p your.app.package": - "Resets all the permissions of an app"- "adb shell pm path <package name>": - "Shows the path to the APK which can be downloaded (see adb pull) even without root permissions."- "adb input touch <x> <y>": - "Perform a touch event at the given coordinates"
DEX Files
Use dex2jar to convert .dex files in .jar files.
d2j-dex2jarclasses.dex-oclasses.jar
Then analyze it with Jadx-gui
Using Nuclei to automate the proccess of finding endpoints and hidden information
Extract APK with APKtool
apktooldapp.apk-oapp_output_directory
Run Nuclei and find secrets keys and vulnerabilities