BACKUP VULNERABILITY
- Layout for this exercise:
data:image/s3,"s3://crabby-images/94790/94790d61145300debf8f6883691ebae9257bf0b8" alt=""
- Connecting Santoku to Nexus 5:
data:image/s3,"s3://crabby-images/006e6/006e6a69d8841dc47b3bd278daaf104b10f9ecb8" alt=""
- Backup and restoration processes in some Android applications are vulnerable because the backup contents can be altered and later restore back without root privileges.
- Some of these vulnerabilities were discovered and investigated by Chris John Riley and Aditya Gutpa.
- In this exercise the Android Backup Extractor (abe) will be used:
https://sourceforge.net/projects/adbextractor/
data:image/s3,"s3://crabby-images/6449d/6449dcf27b3e5bd4a112ac76ddcce8c45713aef8" alt=""
- Once downloaded to Santoku, let's unzip abe:
data:image/s3,"s3://crabby-images/b46e5/b46e5e451bd24a2ea12de5d03b409e15f782049c" alt=""
data:image/s3,"s3://crabby-images/0004d/0004de8f4bdfdf52499e6dcdc805cca0b13d24ec" alt=""
data:image/s3,"s3://crabby-images/6dc8d/6dc8d01df083ee16572003eae2ea842e0d979876" alt=""
data:image/s3,"s3://crabby-images/3128d/3128dbb8e15e38895b3bb298e31d74929fe12105" alt=""
- On the other hand, to test the backup vulnerability, the application box.apk will be used:
data:image/s3,"s3://crabby-images/b86f9/b86f959abd2936b6b16151835c293da85fbe99de" alt=""
- Installing box.apk to the mobile device:
data:image/s3,"s3://crabby-images/76685/76685bcc7bdaf5a09c321ed0c50c740e20e10f16" alt=""
data:image/s3,"s3://crabby-images/d6ae7/d6ae74bb69ca6c057d341da8886e3743c77783e2" alt=""
- Going to Settings, a passcode is introduced:
data:image/s3,"s3://crabby-images/5a948/5a948251045ebce151f44828a2b9b95ccbbcbe97" alt=""
data:image/s3,"s3://crabby-images/c1536/c1536e7f8c45cf8ae1493c5bc10e4be97b2b1de8" alt=""
data:image/s3,"s3://crabby-images/c229c/c229c26dab3f13f3fd2bee7d90c1873ddef8139d" alt=""
- From now, to access the application a passcode is needed after 1 minute of timeout:
data:image/s3,"s3://crabby-images/220cd/220cd91d536cfee40d054fd353c52a57ce4c27df" alt=""
- Detecting the name of the package used by the application:
data:image/s3,"s3://crabby-images/dc43b/dc43b7c3d92608ebbcdb4b394baaee3e5d8039cc" alt=""
- ADB helps to backup the application, from box.apk, creating the new file box.ab. The extension .ab means "android backup":
data:image/s3,"s3://crabby-images/2b5cc/2b5cc5b53d8a77b7eb423c18d14e677088fca31d" alt=""
data:image/s3,"s3://crabby-images/52334/523345b68fd6e728eab0fba14b5c64ff91e9c442" alt=""
- The user is prompted to perform the backup at the mobile device:
data:image/s3,"s3://crabby-images/906af/906afba5256cd6b78de77974edd97720fcb1173b" alt=""
- The backup process is successful:
data:image/s3,"s3://crabby-images/c1861/c1861f8973a0058d9b21da36acb65334f13ca812" alt=""
data:image/s3,"s3://crabby-images/34413/3441345edc1bc97dbfdfb8d8003f6b744bcc525e" alt=""
data:image/s3,"s3://crabby-images/70b54/70b54e18bcdf1c1d749bb0d7a0345cbd9b31bfd6" alt=""
- hexdump shows the hexadecimal content of box.ab, checking that it is actually an Android backup:
data:image/s3,"s3://crabby-images/f20e6/f20e66eeae4110aecdfd8e2185b0418d9c4c09d8" alt=""
data:image/s3,"s3://crabby-images/02996/029962fb7b524f00873e5083063b1206cca56f31" alt=""
- It is important to notice that an Android Backup (*.ab) file is actually a compressed tar file, that can be created with the Android Backup Extractor, so unpacking box.ab to box.tar:
data:image/s3,"s3://crabby-images/5cf25/5cf252afcffef71be9c0d22f0ebe0f327c230626" alt=""
data:image/s3,"s3://crabby-images/09f7a/09f7a1af786d4345148304c3688e3682751a35d8" alt=""
- Extracting with tar, all the files of box.tar are displayed:
data:image/s3,"s3://crabby-images/ab8e5/ab8e5e444757c97bb0f8c3a0ea7ea3a182de03b6" alt=""
- Listing the files of box.tar to a file box.list:
data:image/s3,"s3://crabby-images/e24e8/e24e89f067707c8dc4169d350dd15e77b707e4a8" alt=""
data:image/s3,"s3://crabby-images/7071c/7071cf52809b80a8cfccccf64abae91ef710966c" alt=""
- Now, the whole package com.box.android is available to be analyzed:
data:image/s3,"s3://crabby-images/8a83b/8a83b48f15fdb3173b28bcea8fcfd547824c9e78" alt=""
- Going deeper into the folder's structure down to sp (shared preferences):
data:image/s3,"s3://crabby-images/2a719/2a719689b3c0ddef09f224ebbd32e379733a50e7" alt=""
- Looking up into apps:
data:image/s3,"s3://crabby-images/af933/af93338faf1ca74e4881448050dcc3e2dc17627b" alt=""
- A hardcoded encrypted pin is found at the file myPreference.xml:
data:image/s3,"s3://crabby-images/e4e3f/e4e3fbd996d607fa0b4199b5fd00684d37d582e8" alt=""
- Opening myPreference.xml, the line with the encrypted pin is detected:
data:image/s3,"s3://crabby-images/1f96a/1f96a80db80ed821f00d8e5202cca037c35aec82" alt=""
data:image/s3,"s3://crabby-images/30d87/30d87a1b28348588d7f681f45cc3eb51cb8dd8f2" alt=""
- With the purpose of altering the application, the line corresponding to the encrypted pin is just removed:
data:image/s3,"s3://crabby-images/0ee1f/0ee1fd22e5a3098f9b1b91a86cedc97e3ea761b9" alt=""
- Now, to rebuild the application once it has been altered, the pax command is used:
data:image/s3,"s3://crabby-images/61421/61421cf620835cbfd5e62fff40f47ec9918ea7b3" alt=""
data:image/s3,"s3://crabby-images/3db08/3db080988c80d4e4d9284044f41906566677f521" alt=""
data:image/s3,"s3://crabby-images/0be52/0be52b0cf9dfbef519390ccf5c259dc1fc691682" alt=""
data:image/s3,"s3://crabby-images/fbf7a/fbf7a4574c4e6bd66c1903ae030933153f78ae4c" alt=""
- Redirecting the list of files of box.list (altered) to a new file box1.tar:
data:image/s3,"s3://crabby-images/42e2c/42e2cc06dc410541e210c735e40c3edfb3f338a2" alt=""
data:image/s3,"s3://crabby-images/78732/787326724be0db3a449943199d6fd137bb31d87c" alt=""
- The Android Backup Extractor does the reverse process than before, now packing instead of unpacking, and creating a file box1.ab from the altered box1.tar:
data:image/s3,"s3://crabby-images/08523/085230846f0216fe34922a7246576b514e27ad68" alt=""
data:image/s3,"s3://crabby-images/c9d56/c9d56d46e3bafbc757ee5cff95f377314bf07e82" alt=""
- hexdump shows the hexadecimal content of box1.ab, checking that it is actually an Android backup:
data:image/s3,"s3://crabby-images/18cf3/18cf3b6aae42e5a655c404f0565608ac00c6b3ba" alt=""
data:image/s3,"s3://crabby-images/a4037/a40378eb76b5e98cca3c1b3b3624f7fe1aee5ac2" alt=""
- Restoring the backup with ADB:
data:image/s3,"s3://crabby-images/c0413/c04139d6458af5333222a6cde1eda265cd0a268d" alt=""
- The user is prompted to perform the restoration (notice that neither passcode nor pin is requested):
data:image/s3,"s3://crabby-images/28aaf/28aaf1b812ad707150d3ad8acef682ac8254abe3" alt=""
- The restoration of data is eventually successful:
data:image/s3,"s3://crabby-images/4e711/4e7115a1fedeeea92d8f6f0c1ad9c9358659f215" alt=""
data:image/s3,"s3://crabby-images/2e088/2e088db2c94622ecb1d7c0677e1ecec180368a51" alt=""
data:image/s3,"s3://crabby-images/038f9/038f98bc3d319a6fd15a76dd211a7448049415ca" alt=""
- We can also verify that the alteration is effective, by checking that now the Settings configuration says Require passcode = Never, although we set previously a required passcode:
data:image/s3,"s3://crabby-images/9374c/9374c909e79484416f7ab16646c429830ab508c7" alt=""