Android-sharedUserId数据权限

Android-sharedUserId数据权限

Android给每个APK进程分配一个单独的用户空间,其manifest中的userid就是对应一个Linux用户

(Android系统是基于Linux)的.

所以不同APK(用户)间互相访问数据默认是禁止的.

但是它也提供了2种APK间共享数据的形式:

1.SharePreference./ContentProvider

APK可以指定接口和数据给任何其他APK读取.需要自己实现接口和Share的数据.

写:

shardPreferences=getContext().getSharedPreferences(IP_DIAL_SAVE,Context.MODE_WORLD_READABLE|Context.MODE_WORLD_WRITEABLE);

读:

try{

ContextfriendContext=this.createPackageContext(

"com.cn.numberlocator",

                                Context.CONTEXT_IGNORE_SECURITY);

                        SharedPreferences pref = friendContext.getSharedPreferences("IP_DIAL_SAVE", Context.MODE_WORLD_READABLE | Context.MODE_WORLD_READABLE);

Stringi=pref.getString("IP_NUMBER","abcd");

                        boolean b = pref.contains("IP_NUMBER");

                        Log.d(TAG,"contacts pref simstatus="+ i + " "+b);

                } catch (NameNotFoundException e) {

//TODOAuto-generatedcatchblock

e.printStackTrace();

}

2.SharedUserid

通过SharedUserid,拥有同一个Userid的多个APK可以配置成运行在同一个进程中.所以默认就是

可以互相访问任意数据.也可以配置成运行成不同的进程,同时可以访问其他APK的数据目录下的

数据库和文件.就像访问本程序的数据一样.

比如某个公司开发了多个Android程序,那么可以把数据,图片等资源集中放到APKA中去.然后

这个公司的所有APK都使用同一个UserID,那么所有的资源都可以从APKA中读取.

举个例子:

APKA和APKB都是C公司的产品,那么如果用户从APKA中登陆成功.那么打开APKB的时候就不用

再次登陆.具体实现就是A和B设置成同一个UserID:

*在2个APK的AndroidManifest.xml配置UserID:

<manifestxmlns:android="http://schemas.android.com/apk/res/android"

package="com.android.demo.a1"

android:sharedUserid="com.c">

这个"com.c"就是userid,然后packagenameAPKA就是上面的内容,APKB可能

是"com.android.demo.b1"这个没有限制

这个设定好之后,APKB就可以像打开本地数据库那样打开APKA中的数据库了.

APKA把登陆信息存放在A的数据目录下面.APKB每次启动的时候读取APKA下面的数据库

判断是否已经登陆:

APKB中的代码:

friendContext=this.createPackageContext(

"com.android.demo.a1",

Context.CONTEXT_IGNORE_SECURITY);

通过A的packagename就可以得到A的packagecontext

通过这个context就可以直接打开数据库

相关推荐