I've implemented in app billing in an app, and now I want to secure it a little more. Reading the developer material it states:
In addition to running an obfuscation program, we recommend that you use the following techniques to obfuscate your in-app billing code.
Inline methods into other methods.
Construct strings on the fly instead of defining them as constants.
Use Java reflection to call methods.
http://developer.android.com/guide/market/billing/billing_best_practices.html
Obfuscation - fine I can do that = proguard
Inline methods into other methods - is this saying once my code is complete, get rid of much OO as I can and put all my code in as many lines as I can (for the billing part of my app) in one method? Does this include inlining classes? In the android example they have a constants class, would I inline all these?
Construct strings on the fly - yes so move all class constant variables in line - fine proguard should cover this
Use Java Reflection - this is my main question. Should I invoke all my methods instead of calling them?
To save myself some effort could I do this:
private static Object invokeMethod(String name, Class<?>[] params, Object[] args){
try {
return MySpecificClass.class.getMethod(name, params).invoke(null, args);
} catch (IllegalArgumentException e) {
// Should never happen in my code, ignore and cancel in app charge
} catch (SecurityException e) {
// Should never happen in my code, ignore and cancel in app charge
} catch (IllegalAccessException e) {
// Should never happen in my code, ignore and cancel in app charge
} catch (InvocationTargetException e) {
// Should never happen in my code, ignore and cancel in app charge
} catch (NoSuchMethodException e) {
// Should never happen in my code, ignore and cancel in app charge
}
return null;
}
I could then do things like this:
private static boolean someMethod() {
return true; // just an example
}
params = new Class<?>[0];
if ((Boolean) invokeMethod("someMethod", params, null)) {
// Do something
}
Is this good security, or is it just code bloat and making my app undebuggable for genuine user issues?
Thanks.
This seems like something you could look into when there is a higher demonstrated threat of piracy. I wouldn't be able to justify using reflection just for an extra layer of obfuscation if it had a chance of compromising the user experience.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With