views:

439

answers:

2

In Android documentation concerning code signing we can read: "By signing multiple applications with the same certificate and using signature-based permissions checks, your applications can share code and data in a secure manner."

How exactly such code sharing can be done? Is it possible to release main application and multiple exchangeable plugins then discover them at runtime? What does source code looks like and what are advantages over "standard" intents calls from/to different APK packages?

A: 

In Eclipse, follow this.

right click your project-->properties-->Java Build Path--> projects tab--> add project.

Praveen Chandrasekaran
+2  A: 

Use Context.createPackageContext() to instantiate a package for another .apk you are interested in. If it is signed with the same cert as yours, AND you are both using the same shared user ID, then you can use the flag to load its code into your process, allowing you to get the ClassLoader from the context and instantiate whatever classes you want.

Otherwise, if they are not signed the same and explicitly using the same shared used ID, you can only load its resources.

Please note that you can not change the shared user ID for an application (to something else or moving between having and not having a shared user ID) once that application is on market.

hackbod
More info: http://developer.android.com/intl/de/guide/topics/security/security.html#userid and http://developer.android.com/intl/de/guide/topics/manifest/manifest-element.html
tomash