Android僅允許安裝指定簽名apk

需求:僅允許安裝特定簽名apk拷肌,其它簽名apk禁止安裝。

一旨巷、移植下面代碼

shenhb@dqrd01:~/code/rk3288$ git show 814c25ddd422f8f44a3de9451ef25e296a298ea0
commit 814c25ddd422f8f44a3de9451ef25e296a298ea0
Author: shenhb <shenhb@topband.com.cn>
Date:   Thu Feb 20 11:31:19 2020 +0800

    僅允許安裝指定簽名apk巨缘,通過(guò)屬性ro.signature配置簽名sha1值

diff --git a/frameworks/base/services/core/java/com/android/server/pm/PackageManagerService.java b/frameworks/base
index b7171ba..414a064 100755
--- a/frameworks/base/services/core/java/com/android/server/pm/PackageManagerService.java
+++ b/frameworks/base/services/core/java/com/android/server/pm/PackageManagerService.java
@@ -355,6 +355,7 @@ import java.util.concurrent.TimeUnit;
 import java.util.concurrent.atomic.AtomicBoolean;
 import java.util.concurrent.atomic.AtomicInteger;
 import java.util.zip.GZIPInputStream;
+import java.util.Locale;
 
 /**
  * Keep track of all those APKs everywhere.
@@ -18605,6 +18606,37 @@ public class PackageManagerService extends IPackageManager.Stub
         Trace.traceEnd(TRACE_TAG_PACKAGE_MANAGER);
     }
 
+    // Add by shenhb@topband.com.cn, for only allow the specified signature apk.
+    private static String getFingerprint(Signature signature, String hashAlgorithm) {
+        if (signature == null) {
+            return null;
+        }
+        try {
+            MessageDigest digest = MessageDigest.getInstance(hashAlgorithm);
+            return toHexadecimalString(digest.digest(signature.toByteArray()));
+        } catch (NoSuchAlgorithmException e) {
+            // ignore
+        }
+        return null;
+    }
+
+    private static String toHexadecimalString(byte[] value) {
+        StringBuffer sb = new StringBuffer();
+        int len = value.length;
+        for (int i = 0; i < len; i++) {
+            int num = ((int) value[i]) & 0xff;
+            if (num < 0x10) {
+                sb.append('0');
+            }
+            sb.append(Integer.toHexString(num));
+            if (i < len - 1) {
+                sb.append(':');
+            }
+        }
+        return sb.toString().toUpperCase(Locale.US);
+    }
+    // Add end
+
     private void installPackageTracedLI(InstallArgs args, PackageInstalledInfo res) {
         try {
             Trace.traceBegin(TRACE_TAG_PACKAGE_MANAGER, "installPackage");
@@ -18771,6 +18803,20 @@ public class PackageManagerService extends IPackageManager.Stub
             return;
         }
 
+        // Add by shenhb@topband.com.cn, for only allow the specified signature apk.
+        String customSignature = SystemProperties.get("ro.signature", "");
+        if (!TextUtils.isEmpty(customSignature)) {
+            final Signature[] signatures = pkg.mSignatures;
+            Slog.d(TAG, "installPackageLI, Signature fingerprint "
+                    + getFingerprint(signatures[0], "SHA-1"));
+            if (!getFingerprint(signatures[0], "SHA-1").equals(customSignature)) {
+                res.setError(PackageManager.INSTALL_FAILED_VERIFICATION_FAILURE,
+                        "Signature verification failed");
+                return;
+            }
+        }
+        // Add end
+
         // Get rid of all references to package scan path via parser.
         pp = null;
         String oldCodePath = null;

二、屬性配置簽名sha1

考慮到方案的通用性采呐,因此通過(guò)屬性來(lái)配置簽名若锁。屬性不配置的情況下,走Android默認(rèn)邏輯斧吐,允許安裝所有apk又固。屬性配置后,只允許跟此簽名匹配的apk安裝煤率。

2.1 獲取簽名sha1

  1. 解壓apk文件仰冠,提到META-INF/CERT.RSA(既簽名文件公鑰)。
  2. 執(zhí)行下面命令得到公鑰sha1值蝶糯。
F:\download
λ keytool -printcert -file CERT.RSA
所有者: CN=xxx, OU=xxx, O=xxx, L=xxx, ST=xxx, C=china
發(fā)布者: CN=xxx, OU=xxx, O=xxx, L=xxx, ST=xxx, C=china
序列號(hào): xxxxxxx
有效期開(kāi)始日期: Sun Feb 11 14:38:48 CST 2018, 截止日期: Thu Feb 05 14:38:48 CST 2043
證書(shū)指紋:
         MD5: 13:8A:22:DC:6E:6C:BA:27:42:8D:9F:C5:0D:D2:4E:14
         SHA1: 31:4E:FC:8C:68:FA:7E:F4:14:E7:27:C3:A9:C4:9C:F1:AB:1C:64:C2
         SHA256: 63:E0:0A:FF:45:7C:03:97:F5:27:64:C5:D4:DA:BD:8A:2E:63:40:E7:31:A3:C8:3D:FB:03:00:2A:9F:BE:71:EF
         簽名算法名稱: SHA256withRSA
         版本: 3

擴(kuò)展:

#1: ObjectId: 2.5.29.14 Criticality=false
SubjectKeyIdentifier [
KeyIdentifier [
0000: C9 41 D4 8D F0 58 FF E2   EE EF 7E 5E 3B 9D DA 44  .A...X.....^;..D
0010: 40 E5 DF FC                                        @...
]
]

2.2 配置屬性

ro.signature=31:4E:FC:8C:68:FA:7E:F4:14:E7:27:C3:A9:C4:9C:F1:AB:1C:64:C2

三洋只、驗(yàn)證

驗(yàn)證結(jié)果如下,非指定簽名的apk安裝失敗裳涛,提示“Signature verification failed”木张,指定簽名的apk安裝成功。

λ adb install 001.apk
adb: failed to install 001.apk: Failure [INSTALL_FAILED_VERIFICATION_FAILURE: Signature verification failed]

λ adb install 002.apk
Success
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末端三,一起剝皮案震驚了整個(gè)濱河市舷礼,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌郊闯,老刑警劉巖妻献,帶你破解...
    沈念sama閱讀 222,807評(píng)論 6 518
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蛛株,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡育拨,警方通過(guò)查閱死者的電腦和手機(jī)谨履,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,284評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)熬丧,“玉大人笋粟,你說(shuō)我怎么就攤上這事∥龊” “怎么了害捕?”我有些...
    開(kāi)封第一講書(shū)人閱讀 169,589評(píng)論 0 363
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)闷畸。 經(jīng)常有香客問(wèn)我尝盼,道長(zhǎng)鲤桥,這世上最難降的妖魔是什么著觉? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 60,188評(píng)論 1 300
  • 正文 為了忘掉前任睡榆,我火速辦了婚禮糜芳,結(jié)果婚禮上辩恼,老公的妹妹穿的比我還像新娘烁试。我一直安慰自己完沪,他們只是感情好丸边,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,185評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布凸舵。 她就那樣靜靜地躺著祖娘,像睡著了一般。 火紅的嫁衣襯著肌膚如雪啊奄。 梳的紋絲不亂的頭發(fā)上渐苏,一...
    開(kāi)封第一講書(shū)人閱讀 52,785評(píng)論 1 314
  • 那天,我揣著相機(jī)與錄音菇夸,去河邊找鬼琼富。 笑死,一個(gè)胖子當(dāng)著我的面吹牛庄新,可吹牛的內(nèi)容都是我干的鞠眉。 我是一名探鬼主播,決...
    沈念sama閱讀 41,220評(píng)論 3 423
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼择诈,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼械蹋!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起羞芍,我...
    開(kāi)封第一講書(shū)人閱讀 40,167評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤哗戈,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后荷科,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體唯咬,經(jīng)...
    沈念sama閱讀 46,698評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡纱注,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,767評(píng)論 3 343
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了胆胰。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片狞贱。...
    茶點(diǎn)故事閱讀 40,912評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖蜀涨,靈堂內(nèi)的尸體忽然破棺而出瞎嬉,到底是詐尸還是另有隱情,我是刑警寧澤勉盅,帶...
    沈念sama閱讀 36,572評(píng)論 5 351
  • 正文 年R本政府宣布佑颇,位于F島的核電站,受9級(jí)特大地震影響草娜,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜痒筒,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,254評(píng)論 3 336
  • 文/蒙蒙 一宰闰、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧簿透,春花似錦移袍、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,746評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至啡浊,卻和暖如春觅够,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背巷嚣。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,859評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工喘先, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人廷粒。 一個(gè)月前我還...
    沈念sama閱讀 49,359評(píng)論 3 379
  • 正文 我出身青樓窘拯,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親坝茎。 傳聞我的和親對(duì)象是個(gè)殘疾皇子涤姊,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,922評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容