Android apk 系統(tǒng)簽名

因工作需要對系統(tǒng)的wifi和以太網(wǎng)進(jìn)行配置,需要獲取到系統(tǒng)權(quán)限以后才能進(jìn)行操作瓮床,因此研究了下對apk 進(jìn)行系統(tǒng)簽名以獲取系統(tǒng)權(quán)限盹舞,其實本來打算如果root可以的話直接通過root的方式(設(shè)備已經(jīng)root)隘庄,后來找了半天發(fā)現(xiàn)沒有api進(jìn)行修改,無奈只能進(jìn)行系統(tǒng)簽名了丑掺,有童鞋知道root方式修改不妨告訴我一下。

一兼丰、簽名的準(zhǔn)備。

1鳍征、獲取到platform.pk8、platform.x509.pem艳丛、signapk.jar、libconscrypt_openjdk_jni.so(不一定用到)等文件氮双。

這些文件可以問系統(tǒng)廠商獲取,如果是原生系統(tǒng)可以到系統(tǒng)源碼目錄下獲取戴差。

2唧躲、一臺裝有Linux系統(tǒng)的電腦或者在自己電腦裝Linux虛擬機(jī)。

二弄痹、在apk基礎(chǔ)上進(jìn)行簽名

1、在app的AndroidManifest.xml manifest節(jié)點加上

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.test.demo2"
    android:sharedUserId="android.uid.system">
</manifest>

2肛真、加上我們需要的權(quán)限


    <uses-permission android:name="android.permission.SET_TIME" />
    <uses-permission android:name="android.permission.SET_TIME_ZONE" />

    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />

    <uses-permission android:name="android.permission.WRITE_SETTINGS" />
    <uses-permission android:name="android.permission.WRITE_SECURE_SETTINGS" />
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />

3、打包生成我們的apk,然后把上面準(zhǔn)備階段的幾個文件復(fù)制到Linux同一個目錄下。我這里是Ubuntu讥珍。

image.png

4.使用命令進(jìn)行簽名.

java  -jar signapk.jar platform.x509.pem platform.pk8 unsigned.apk signed.apk

如果報以下的錯誤 ,這時候就用到準(zhǔn)備的libconscrypt_openjdk_jni.so 文件

image.png

在命令中加上
-Djava.library.path=. : 設(shè)置library的路徑 這里設(shè)置為當(dāng)前路徑衷佃。
unsigned.apk :未簽名的apk
signed.apk :已簽名的apk

java -Djava.library.path=. -jar signapk.jar platform.x509.pem platform.pk8 unsigned.apk signed.apk
image.png

5得到簽名后的apk 進(jìn)行安裝

image.png

6蹄葱、驗證我們的apk

為了檢測我們的應(yīng)用是否已經(jīng)簽名成功 可以獲取系統(tǒng)權(quán)限,看看能否獲取到图云。


    /**
     * 判斷是否是系統(tǒng)app
     *
     * @param packageName 包名
     * @return true 是系統(tǒng)app  false 不是系統(tǒng)app
     */
    public static boolean isSystemApp(Context context, String packageName) {
        PackageManager pm = context.getPackageManager();
        //下面是一個系統(tǒng)級權(quán)限 通過判斷是否有系統(tǒng)權(quán)限來判斷是否是系統(tǒng)app
        boolean permission = (PackageManager.PERMISSION_GRANTED == pm.checkPermission("android.permission.OVERRIDE_WIFI_CONFIG", packageName));
        Log.e("TAG", "系統(tǒng)應(yīng)用" + permission + "");
        return permission;
    }


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
               Log.e("TAG", "已簽名:   " + isSystemApp(getApplicationContext(), getPackageName()));
               setContentView(R.layout.activity_main);
         }

結(jié)果:


image.png

三、生成jks或者keystore文件

在上一種方式中克婶,我們成功對我們的apk進(jìn)行了系統(tǒng)簽名,并且能使用系統(tǒng)權(quán)限情萤,但是必須每次打包出apk再進(jìn)行簽名 對調(diào)試很不方便,下面我們可以生成帶有系統(tǒng)簽名的簽名文件紫岩,在項目中使用,就不需要每次手動進(jìn)行簽名泉蝌。

1、1.生成shared.priv.pem 文件

openssl pkcs8 -in platform.pk8 -inform DER -outform PEM -out shared.priv.pem -nocrypt

2勋陪、生成shared.pk12文件

openssl pkcs12 -export -in platform.x509.pem -inkey shared.priv.pem -out shared.pk12 -name bubble

bubble可以替換為自己喜歡的名稱,這一步要輸入密碼,我嘗試輸入其他不行诅愚,只能輸入android。

3违孝、生成jks 或者 keystone文件

keytool -importkeystore -deststorepass android -destkeypass  android -destkeystore bubble.jks -srckeystore shared.pk12 -srcstoretype PKCS12 -srcstorepass android -alias bubble

bubble 可替換為自己喜歡的password和alias

image.png

4泳赋、在項目中使用

    signingConfigs {
        release {
            keyAlias 'bubble'
            keyPassword 'android'
            storePassword 'android'
            storeFile file('../keystore/bubble.jks')
        }
    }

    buildTypes {
        release {
            signingConfig signingConfigs.release
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
        }
    }

5、打包安裝

image.png

到這里 兩種對app進(jìn)行系統(tǒng)簽名的方式完成校坑,如有不足拣技,歡迎指出.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末膏斤,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子邪驮,更是在濱河造成了極大的恐慌,老刑警劉巖耕捞,帶你破解...
    沈念sama閱讀 219,039評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡较曼,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評論 3 395
  • 文/潘曉璐 我一進(jìn)店門捷犹,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人萍歉,你說我怎么就攤上這事∏购ⅲ” “怎么了?”我有些...
    開封第一講書人閱讀 165,417評論 0 356
  • 文/不壞的土叔 我叫張陵蔑舞,是天一觀的道長。 經(jīng)常有香客問我攻询,道長,這世上最難降的妖魔是什么钧栖? 我笑而不...
    開封第一講書人閱讀 58,868評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮拯杠,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘阴挣。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,892評論 6 392
  • 文/花漫 我一把揭開白布揖膜。 她就那樣靜靜地躺著,像睡著了一般壹粟。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上宿百,一...
    開封第一講書人閱讀 51,692評論 1 305
  • 那天,我揣著相機(jī)與錄音雀费,去河邊找鬼。 笑死痊焊,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的薄啥。 我是一名探鬼主播,決...
    沈念sama閱讀 40,416評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼刁愿,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了到逊?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,326評論 0 276
  • 序言:老撾萬榮一對情侶失蹤枷踏,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后掰曾,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,782評論 1 316
  • 正文 獨居荒郊野嶺守林人離奇死亡掏熬,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,957評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了旗芬。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,102評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡疮丛,死狀恐怖幔嫂,靈堂內(nèi)的尸體忽然破棺而出誊薄,到底是詐尸還是另有隱情,我是刑警寧澤呢蔫,帶...
    沈念sama閱讀 35,790評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站片吊,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏俏脊。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,442評論 3 331
  • 文/蒙蒙 一联予、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧沸久,春花似錦、人聲如沸卷胯。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至担钮,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間尤仍,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評論 1 272
  • 我被黑心中介騙來泰國打工宰啦, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人赡模。 一個月前我還...
    沈念sama閱讀 48,332評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像漓柑,于是被迫代替她去往敵國和親叨吮。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,044評論 2 355

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