<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免费版| 免费看无码自慰一区二区| avtt天堂网手机版亚洲| 成人免费午夜无码视频| 亚洲影院天堂中文av色| 全免费a级毛片免费看不卡| 亚洲成AV人影片在线观看| 日韩免费电影在线观看| 乱爱性全过程免费视频| 亚洲一区二区三区影院| 中文字幕乱码一区二区免费| 亚洲国产成人私人影院| 国产91免费在线观看| 蜜桃AV无码免费看永久| 亚洲人成免费电影| 日韩免费视频一区| 国产裸体美女永久免费无遮挡| 亚洲国产精品一区二区成人片国内| 免费国产叼嘿视频大全网站| 亚洲福利视频网址| 国产乱色精品成人免费视频 | 猫咪免费观看人成网站在线| 免费欧洲美女牲交视频| 精品无码一级毛片免费视频观看| 亚洲精品无码鲁网中文电影| 最近中文字幕电影大全免费版| 亚洲男人天堂2018av| 亚洲AV无码乱码在线观看| 久久久久久久99精品免费观看 | 亚洲va无码专区国产乱码| 亚洲人成免费网站| 香蕉视频免费在线| 亚洲AV无码成人网站久久精品大| 黄页网站免费在线观看| 国产免费福利体检区久久| 亚洲国产精品日韩在线| 亚洲精品高清一二区久久| 7x7x7x免费在线观看| 香蕉视频免费在线播放|