Allows WhatsApp users to extract their cipher key and databases on non-rooted Android 13 or lower devices.
Android 14 and newer ARE NOT SUPPORTED!
Tip
Crypt15 encrypted_backup.key is now supported!
Caution
By default, this script use the old WhatsApp APK from WhatsApp.com (in Web Archive), use it at your own risk.
Important
Always create a backup through the official WhatsApp app if possible before trying or you risk lossing all your data...
Checksum are as follows:
- 51a387f08debd7e53bcaf9f3174760930787bc5c1dcefb3c8d7ee52b524cd27d WhatsApp.apk (2.11.431)
Source:
- WhatsApp.apk: https://web.archive.org/web/20141111030303/http://www.whatsapp.com/android/current/WhatsApp.apk
v4.0 - Fixed issues with Android API 14-17 (4.0-4.2 Jelly Bean).
v4.1 - Added support for Android API 23 (6.0-6.0.1 Marshmallow).
v4.2 - Added support for specifying adb backup passwords.
v4.3 - Added PowerShell version as optional alternative to bat version.
v4.4 - Changed primary mirror for legacy apk.
v4.5 - Fixed issue pushing cipher key to emulated storage.
v4.6 - Updated primary mirror for legacy apk (again).
v4.7 - Added new sanity checks and support for Android API 24 (7.0 Nougat).
v5.0 - Fixed the link of legacy apk.
v5.1 - Added support for Crypt15.
v5.2 - Fixed the link of legacy apk.
v5.3 - Added a pause for users accepting the permissions request.
v5.4 - Updated the binaries for ABE and CURL.
- O/S: Windows 10, Windows 11, Mac OS X or Linux
- Java - If not installed: https://www.java.com/en/download/
- ADB (Android Debug Bridge) Drivers: https://developer.android.com/tools/releases/platform-tools
- USB Debugging must be enabled on the target device. Settings -> Developer Options -> (Debugging) USB debugging
If you cannot find Developer Options then please go to: Settings -> About phone/device and tap the Build number
multiple times until you're finally declared a developer. - Android device running version 4.0 or higher, but lower than Android 14.
- Extract "WhatsApp-Key-DB-Extractor-master.zip" maintaining the directory structure.
- Click on "WhatsAppKeyDBExtract.bat" (Windows) or "WhatsAppKeyDBExtract.sh" (Mac OS X / Linux).
- Connect your device via USB, unlock your screen and wait for "Full backup" or the permission request screen to appear.
- Enter your backup password or leave blank (if none set) and tap on "Back up my data".
- Confirm backup password in your command console and then check your "extracted" folder.
- If you have never used USB Debugging before, you may also need to verify the fingerprint.
- If you have set a default backup password in your Android settings, then this MUST be the
backup password that you PROVIDE when prompted to backup your data. Else it WILL fail! - Linux and Mac OS X users may need to set the script permissions as executable. Depending on the
adb permissions, you may also need to "sudo ./WhatsAppKeyDBExtract.sh" from your command console. - If you're having issues with "WhatsAppKeyDBExtract.bat" then right click "WhatsAppKeyDBExtract.ps1"
and select "Run with PowerShell". You may have to enter "y" at first run for execution policy. - If you get an error saying "AES encryption not allowed" then you need to update your Oracle Java
Cryptography Extension (JCE) to Unlimited Strength Jurisdiction Policy Files.
AUTHOR: TripCode
MAINTAINER: KnugiHK
THANKS: dragomerlin for Android Backup Extractor and Abinash Bishoyi for being cool.
abe.jar by nelenkov and its contributors.
tar.exe, grep.exe, regex2.dll, libintl3.dll, libiconv2.dll by Free Software Foundation and its contributors.
pcre3.dll by University of Cambridge and its contributors.
curl.exe by Daniel Stenberg and its contributors.
adb.exe, AdbWinApi.dll, AdbWinUsbApi.dll by The Android Open Source Project and its contributors.
SPDX-License-Identifier: Apache-2.0 OR GPL-3.0