Android Tutorial Protect your application against copy and changes

This method uses the F5Steg and PackageUtils libraries from ProBundle.

There's a demo available in the Play Store: https://play.google.com/store/apps/details?id=b4a.protecthw.flm
The source code is attached to this message and is used as a reference in the following explanations. It will not work after compilation on your computer because some of the assets are protected. Only the creator of these resources (me) can compile a working version.

Protection against copy:
If you look at the source code, you can see that the copy protection is quite simple since it is all in these three lines:
B4X:
If PU.GetInstallerPackageName(PU.GetMyPackageName) = Null Or PU.GetInstallerPackageName(PU.GetMyPackageName) <> "com.android.vending" Then
   ExitApplication
End If
If the installation source is not the Play Store ("com.android.vending"), the program ends.
This protection would be very weak if a malicious person could remove these lines with a tool like apktool, so the APK must also be protected against modification.

Protection against changes:
To protect the APK against modification, I use the F5Steg library. It can encrypt data inside an image using the APK signature. No password is required from the user. The encryption password is automatically created by the library's C code from the signature (and I won't explain how, of course, because otherwise it would be a piece of cake to circumvent this protection). If someone modifies the program, he has to reassemble it and sign it with his own key. This will change the signature and therefore F5Steg will not be able to decrypt the image correctly.

In the demo, the image containing the encrypted data is "logo.jpg". In this image, I encoded a list with two entries: a password (which is used to decompress the "value.zip" archive) and a Map which contains three data (an integer, a floating number and the name of the image with my picture). Without these data, the application cannot calculate anything correctly when the user clicks the Test button.

If you use this method to protect your application, a small donation (by clicking on the Donate button in my signature) will be greatly appreciated.
 

Attachments

  • Challenge.zip
    71.3 KB · Views: 981

MarcoRome

Expert
Licensed User
Longtime User
Hi Informatix. Good work ( as usual ).
Where can i found library:



Thank you
Have a nice day
Marco
 

MarcoRome

Expert
Licensed User
Longtime User
Hi Fred.
When i try the example i have this error in this line (73):

B4X:
F5S.ExtractToArray(File.Combine(File.DirInternalCache, EncryptedImage), "B4A")


Thank you
Marco
 

Attachments

  • f5steg_64.jar
    353.8 KB · Views: 546

Informatix

Expert
Licensed User
Longtime User
Please read the first post: "It will not work after compilation on your computer because some of the assets are protected. Only the creator of these resources (me) can compile a working version."
 

Informatix

Expert
Licensed User
Longtime User
I used the APKCombo downloader to retrieve my protected demo from the Play Store and installed it on a device, then ran it. It exited immediately. Here's the unfiltered log:
 

peter93

Member
Licensed User
Longtime User
By testing this:
<If PU.GetInstallerPackageName(PU.GetMyPackageName) = Null Or PU.GetInstallerPackageName(PU.GetMyPackageName) <> "com.android.vending" then />
I don't get the "com.android.vending" response I was expecting.
but "com.google.android.packageinstaller". Is that normal?
 

Informatix

Expert
Licensed User
Longtime User
Do you install from the Play Store ? Did you enable the automatic update of your app ?
 

peter93

Member
Licensed User
Longtime User
Do you install from the Play Store ? Did you enable the automatic update of your app ?
I upgraded directly with B4A Bridge and tested it.
But the app comes from the Google Play Store and the license check works well.
I will deliver the app on Google play and redo the test...
 

Informatix

Expert
Licensed User
Longtime User
I upgraded directly with B4A Bridge and tested it.
But the app comes from the Google Play Store and the license check works well.
I will deliver the app on Google play and redo the test...
You have to install directly from the Play Store or the protection means nothing.
Note that the license check is useless if your app is not protected against changes (it can be removed in 5 minutes).
 

quansofts

Member
Hi Informatix,
What if I decompile the apk file =>dex file => get java class files => remove your protection code => recompile the apk

Regards,
 

ArminKh1993

Active Member
You have to install directly from the Play Store or the protection means nothing.
Note that the license check is useless if your app is not protected against changes (it can be removed in 5 minutes).
So what about other markets? galaxy store, huawei , ...
 

73Challenger

Active Member
Licensed User
Question please. Could you post how we can create our own encoded jpg and zip file so it will work with your example code? Any guidance, a description, a link or sample code would be very helpful and appreciated. Thank you!
 

CyberDroidWare

Member
Licensed User
Maybe I haven't read this properly but what is to stop an experienced reverse engineer from swapping the ExitApplication logic?
 
Cookies are required to use this site. You must accept them to continue using the site. Learn more…