Blogger Scott

          Android權(quán)限之sharedUserId和簽名

              轉(zhuǎn)自:http://blog.csdn.net/hmg25/article/details/6447067

              最近在做個(gè)東西,巧合碰到了sharedUserId的問題,所以收集了一些資料,存存檔備份。

              安裝在設(shè)備中的每一個(gè)apk文件,Android給每個(gè)APK進(jìn)程分配一個(gè)單獨(dú)的用戶空間,其manifest中的userid就是對(duì)應(yīng)一個(gè)Linux用戶都會(huì)被分配到一個(gè)屬于自己的統(tǒng)一的Linux用戶ID,并且為它創(chuàng)建一個(gè)沙箱,以防止影響其他應(yīng)用程序(或者其他應(yīng)用程序影響它)。用戶ID 在應(yīng)用程序安裝到設(shè)備中時(shí)被分配,并且在這個(gè)設(shè)備中保持它的永久性。

          通過Shared User id,擁有同一個(gè)User id的多個(gè)APK可以配置成運(yùn)行在同一個(gè)進(jìn)程中.所以默認(rèn)就是可以互相訪問任意數(shù)據(jù). 也可以配置成運(yùn)行成不同的進(jìn)程, 同時(shí)可以訪問其他APK的數(shù)據(jù)目錄下的數(shù)據(jù)庫(kù)和文件.就像訪問本程序的數(shù)據(jù)一樣.

          對(duì)于一個(gè)APK來說,如果要使用某個(gè)共享UID的話,必須做三步:

          1、在Manifest節(jié)點(diǎn)中增加android:sharedUserId屬性。

          2、在Android.mk中增加LOCAL_CERTIFICATE的定義。

          如果增加了上面的屬性但沒有定義與之對(duì)應(yīng)的LOCAL_CERTIFICATE的話,APK是安裝不上去的。提示錯(cuò)誤是:Package com.test.MyTest has no signatures that match those in shared user android.uid.system; ignoring!也就是說,僅有相同簽名和相同sharedUserID標(biāo)簽的兩個(gè)應(yīng)用程序簽名都會(huì)被分配相同的用戶ID。例如所有和media/download相關(guān)的APK都使用android.media作為sharedUserId的話,那么它們必須有相同的簽名media。

          3、把APK的源碼放到packages/apps/目錄下,用mm進(jìn)行編譯。

          舉例說明一下。

          系統(tǒng)中所有使用android.uid.system作為共享UID的APK,都會(huì)首先在manifest節(jié)點(diǎn)中增加android:sharedUserId="android.uid.system",然后在Android.mk中增加LOCAL_CERTIFICATE := platform。可以參見Settings等

          系統(tǒng)中所有使用android.uid.shared作為共享UID的APK,都會(huì)在manifest節(jié)點(diǎn)中增加android:sharedUserId="android.uid.shared",然后在Android.mk中增加LOCAL_CERTIFICATE := shared。可以參見Launcher等

          系統(tǒng)中所有使用android.media作為共享UID的APK,都會(huì)在manifest節(jié)點(diǎn)中增加android:sharedUserId="android.media",然后在Android.mk中增加LOCAL_CERTIFICATE := media。可以參見Gallery等。

          另外,應(yīng)用創(chuàng)建的任何文件都會(huì)被賦予應(yīng)用的用戶標(biāo)識(shí),并且正常情況下不能被其他包訪問。當(dāng)通過getSharedPreferences(String,int)、openFileOutput(String、int)或者openOrCreate Database(String、int、SQLiteDatabase.CursorFactory)創(chuàng)建一個(gè)新文件時(shí),開發(fā)者可以同時(shí)或分別使用MODE_WORLD_READABLE和MODE_WORLD_RITEABLE標(biāo)志允許其他包讀/寫此文件。當(dāng)設(shè)置了這些標(biāo)志后,這個(gè)文件仍然屬于自己的應(yīng)用程序,但是它的全局讀/寫和讀/寫權(quán)限已經(jīng)設(shè)置,所以其他任何應(yīng)用程序可以看到它。

          關(guān)于簽名:

          build/target/product/security目錄中有四組默認(rèn)簽名供Android.mk在編譯APK使用:

          1、testkey:普通APK,默認(rèn)情況下使用。

          2、platform:該APK完成一些系統(tǒng)的核心功能。經(jīng)過對(duì)系統(tǒng)中存在的文件夾的訪問測(cè)試,這種方式編譯出來的APK所在進(jìn)程的UID為system。

          3、shared:該APK需要和home/contacts進(jìn)程共享數(shù)據(jù)。

          4、media:該APK是media/download系統(tǒng)中的一環(huán)。

          應(yīng)用程序的Android.mk中有一個(gè)LOCAL_CERTIFICATE字段,由它指定用哪個(gè)key簽名,未指定的默認(rèn)用testkey.

           

           

          對(duì)于使用eclipse編譯的apk,可以使用signapk.jar來手動(dòng)進(jìn)行簽名,其源碼在build/tools/signapk下,編譯后在out/host/linux-x86/framework/signapk.jar,也可以從網(wǎng)上下載。使用方法,以platform為例:java -jar ./signapk platform.x509.pem platform.pk8 input.apk output.apk  (platform.x509.pem platform.pk8在build/target/product/security獲取)

          posted on 2011-10-19 10:00 江天部落格 閱讀(29160) 評(píng)論(0)  編輯  收藏 所屬分類: Android

          主站蜘蛛池模板: 灵川县| 池州市| 牙克石市| 香港| 齐河县| 吉木萨尔县| 营口市| 沙湾县| 盘锦市| 黄浦区| 高平市| 晋江市| 团风县| 德阳市| 兴和县| 滁州市| 平远县| 临武县| 大埔区| 申扎县| 定日县| 盐亭县| 长岛县| 清徐县| 温州市| 红桥区| 新乡县| 康平县| 武功县| 中牟县| 永济市| 义马市| 陵水| 富锦市| 固原市| 溧水县| 鄂州市| 皮山县| 巴林左旗| 莲花县| 邹城市|