<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    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就是對應(yīng)一個(gè)Linux用戶都會被分配到一個(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ù)庫和文件.就像訪問本程序的數(shù)據(jù)一樣.

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

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

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

    如果增加了上面的屬性但沒有定義與之對應(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)用程序簽名都會被分配相同的用戶ID。例如所有和media/download相關(guān)的APK都使用android.media作為sharedUserId的話,那么它們必須有相同的簽名media。

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

    舉例說明一下。

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

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

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

    另外,應(yīng)用創(chuàng)建的任何文件都會被賦予應(yīng)用的用戶標(biāo)識,并且正常情況下不能被其他包訪問。當(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)過對系統(tǒng)中存在的文件夾的訪問測試,這種方式編譯出來的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.

     

     

    對于使用eclipse編譯的apk,可以使用signapk.jar來手動進(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 江天部落格 閱讀(29158) 評論(0)  編輯  收藏 所屬分類: Android

    主站蜘蛛池模板: 亚洲人成网www| 亚洲国产高清国产拍精品| 99久久国产免费中文无字幕| 亚洲欧美国产日韩av野草社区| 亚洲第一福利视频| 久久久久亚洲精品天堂久久久久久 | 亚洲午夜精品一区二区公牛电影院| 久久久青草青青国产亚洲免观 | 亚洲高清无码专区视频| 在线播放高清国语自产拍免费| 3344永久在线观看视频免费首页| 国产成人无码免费网站| 人妻无码中文字幕免费视频蜜桃| 亚洲精品一卡2卡3卡四卡乱码| 亚洲免费在线观看视频| 亚洲精品自拍视频| 亚洲精品免费观看| 亚洲国产成人久久精品动漫 | 成年网站免费入口在线观看| 亚洲Av永久无码精品黑人| 亚洲色大网站WWW永久网站| 久久久久国产成人精品亚洲午夜| 国产免费午夜a无码v视频| 麻豆国产人免费人成免费视频| 97无码免费人妻超级碰碰碰碰| 久久久久久久免费视频| 97碰公开在线观看免费视频| 久久国产精品2020免费m3u8| 亚洲av永久无码| 亚洲爆乳大丰满无码专区| 亚洲欧美成人综合久久久| 一本色道久久88亚洲精品综合| 久久久久久亚洲精品影院| 亚洲一区二区三区深夜天堂| 亚洲一级黄色大片| 亚洲熟女精品中文字幕| 亚洲精品天堂成人片AV在线播放 | 国产一级特黄高清免费大片| 国产大片线上免费看| 青青青国产色视频在线观看国产亚洲欧洲国产综合 | 亚洲色欲或者高潮影院|