若是你須要開發一個帶有系統權限的app,每每須要配置SharedUserId,好比:html
[html] view plain copyjava
此時,若是直接在AS中run,app是裝不上的,須要先生成app,而後再使用系統文件對apk進行簽名,linux
java -jar signapk.jar platform.x509.pem platform.pk8 signDemo.apk signDemo_signed.apk
這樣才能將apk安裝到手機上。android
雖然可以知足使用,可是做爲開發者,難免會遇到須要調試的狀況,而後這種離線的簽名方式,就無法調試。。。嚴重影響了開發的效率,所以,本文介紹一中在線打包簽名的方式。git
須要準備的文件:github
keytool-importkeypair (下載)shell
platform.x509.pem、platform.pk8(位於../build/target/product/security)windows
其本質的原理是給apk加上開發者簽名(jks文件),使用keytool-importkeypair 對jks文件進行系統簽名,在出包的時候,直接使用帶有系統簽名的jks對apk進行簽名,這樣編譯生成的apk文件就自帶系統簽名了app
一、生成你本身的jks文件gradle
若是沒有的就新建,點擊Create New ... 設置密碼(123456)
而後Next -- Finish
二、使用keytool-importkeypair對jks文件引入系統簽名
把platform.x509.pem、platform.pk8和上一部生成的jks文件統一放到一個文件夾下,好比個人是放在工程目錄的signAPK目錄下
將下載好的keytool-importkeypair配置一下,其實主要就是配置一下環境變量,不熟悉的能夠閱讀官方文檔,而後使用下面這條命令(須要在linux下,用windows的能夠去在linux下生成jks,而後複製出新的jks回原目錄也能夠)對jks文件引入系統簽名
./keytool-importkeypair -k [jks文件名] -p [jks的密碼] -pk8 platform.pk8 -cert platform.x509.pem -alias [jks的別名]
例如個人對應的就是:
./keytool-importkeypair -k SignDemo.jks -p 123456 -pk8 platform.pk8 -cert platform.x509.pem -alias SignDemo
運行完這條命令以後,咱們就獲得了有系統簽名的jks
三、配置gradle(app)
在在android區域下(與defaultConfig同級)添加signingConfigs配置:
依次填寫jks的路徑,密碼,別名等
apply plugin: 'com.android.application' android { compileSdkVersion 23 buildToolsVersion "23.0.2" defaultConfig { applicationId "com.cxq.signdemo" minSdkVersion 19 targetSdkVersion 23 versionCode 1 versionName "1.0" } signingConfigs { release { storeFile file("../signApk/SignDemo.jks") storePassword '123456' keyAlias 'SignDemo' keyPassword '123456' } debug { storeFile file("../signApk/SignDemo.jks") storePassword '123456' keyAlias 'SignDemo' keyPassword '123456' } } buildTypes { release { minifyEnabled false proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' } } } dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) testCompile 'junit:junit:4.12' compile 'com.android.support:appcompat-v7:23.3.0' }
四、運行
通過以上配置以後,點擊run,app就能夠直接安裝到手機上了