溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

Android中打包的方式有哪些

發(fā)布時(shí)間:2020-12-04 16:24:23 來(lái)源:億速云 閱讀:137 作者:Leah 欄目:移動(dòng)開(kāi)發(fā)

今天就跟大家聊聊有關(guān)Android中打包的方式有哪些,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

01.應(yīng)用的打包簽名什么是打包?

打包就是根據(jù)簽名和其他標(biāo)識(shí)生成安裝包。

簽名是什么?

1.在android應(yīng)用文件(apk)中保存的一個(gè)特別字符串

2.用來(lái)標(biāo)識(shí)不同的應(yīng)用開(kāi)發(fā)者:開(kāi)發(fā)者A,開(kāi)發(fā)者B

3.一個(gè)應(yīng)用開(kāi)發(fā)者開(kāi)發(fā)的多款應(yīng)用使用同一個(gè)簽名

就好比是一個(gè)人寫(xiě)文章,簽名就相當(dāng)于作者的署名。

如果兩個(gè)應(yīng)用都是一個(gè)開(kāi)發(fā)者開(kāi)發(fā)的,那么簽名就是一樣的。

這個(gè)開(kāi)發(fā)者,可以是個(gè)人,也可以是公司、團(tuán)體。

為什么要用簽名?原因1:最簡(jiǎn)單直接的回答: 系統(tǒng)要求的。

Android系統(tǒng)要求每一個(gè)Android應(yīng)用程序必須要經(jīng)過(guò)數(shù)字簽名才能夠安裝到系統(tǒng)中,也就是說(shuō)如果一個(gè)Android應(yīng)用程序沒(méi)有經(jīng)過(guò)數(shù)字簽名,是沒(méi)有辦法安裝到系統(tǒng)中的!

原因2:

不同程序員開(kāi)發(fā)的應(yīng)用包名可能會(huì)相同, 導(dǎo)致一個(gè)應(yīng)用覆蓋掉另一個(gè)應(yīng)用。

如果只有包名的概念,那么如果B應(yīng)用與已經(jīng)安裝的A應(yīng)用包名一樣,那就實(shí)現(xiàn)覆蓋。不合理!

而事實(shí)上是裝不上B的,它會(huì)提示,存在包名一致,但是簽名不一樣的。這就不會(huì)覆蓋。

如何為APK簽名?

如何簽名就不用說(shuō)了,這方面的博文數(shù)不勝數(shù),相信看這篇文章的你也應(yīng)該會(huì)。

在代碼中得到應(yīng)用的簽名?(個(gè)人覺(jué)得沒(méi)啥用)

public void getSingInfo() {
  try {
    PackageInfo packageInfo = getPackageManager().getPackageInfo(
        "應(yīng)用包名", PackageManager.GET_SIGNATURES);
    Signature[] signs = packageInfo.signatures;
    Signature sign = signs[0];
    parseSignature(sign.toByteArray());
  } catch (Exception e) {
    e.printStackTrace();
  }
}
public void parseSignature(byte[] signature) {
  try {
    CertificateFactory certFactory = CertificateFactory
        .getInstance("X.509");
    X509Certificate cert = (X509Certificate) certFactory
        .generateCertificate(new ByteArrayInputStream(signature));
    String pubKey = cert.getPublicKey().toString();
    String signNumber = cert.getSerialNumber().toString();
    Log.e("TAG", "pubKey:" + pubKey);
    Log.e("TAG", "signNumber:" + signNumber);
  } catch (Exception e) {
    e.printStackTrace();
  }
}

注意問(wèn)題:

現(xiàn)象:

Android導(dǎo)出APK包時(shí)出現(xiàn),編譯調(diào)試時(shí)不會(huì)出現(xiàn)。

錯(cuò)誤信息:

Error:(16) Error: “baidutieba_client_inavailable” is not translated in “en” (English) [MissingTranslation]
Error:(63) Error: “baidutieba” is not translated in “en” (English) [MissingTranslation]
Error:(67) Error: “share_to_baidutieba” is not translated in “en” (English) [MissingTranslation]

錯(cuò)誤截圖:

Android中打包的方式有哪些 

解決辦法:

resources 標(biāo)簽內(nèi)增加兩個(gè)屬性即可:

<&#63;xml version="1.0" encoding="utf-8" &#63;> 
<resources xmlns:tools="http://schemas.android.com/tools" 
 tools:ignore="MissingTranslation"> 
</resources>

02.友盟的多渠道打包說(shuō)明:1.什么是多渠道包?

渠道包就是要在安裝包中添加渠道信息,也就是channel,對(duì)應(yīng)不同的渠道,例如:小米市場(chǎng)、360市場(chǎng)、應(yīng)用寶市場(chǎng)等

2.為什么要提供多渠道包?

我們要在安裝包中添加不同的標(biāo)識(shí),應(yīng)用在請(qǐng)求網(wǎng)絡(luò)的時(shí)候攜帶渠道信息,方便后臺(tái)做運(yùn)營(yíng)統(tǒng)計(jì)(這就是添加渠道信息的用處)。

3.實(shí)現(xiàn)多渠道打包的原理:

一般來(lái)講,這個(gè)渠道的標(biāo)識(shí)會(huì)放在AndroidManifest.xml的Application的一個(gè)Metadata中。然后就可以在java中通過(guò)API獲取對(duì)應(yīng)的數(shù)據(jù)了。

4.如何實(shí)現(xiàn)?

現(xiàn)在android渠道多種多樣,其實(shí)渠道不僅僅局限于應(yīng)用市場(chǎng),一種推廣方式也可以看做一個(gè)渠道,比如:通過(guò)人拉人的方式去推廣,官網(wǎng)上推廣,百度推廣等。所以說(shuō)渠道成千上萬(wàn),為了推廣,有時(shí)候一次也會(huì)打成千的安裝包,那你半天或者一天啥都別干了,所以介紹幾個(gè)大公司高效的打包方式,借鑒一下。

第一種:友盟就提供了多渠道打包的方式,可用于渠道統(tǒng)計(jì)等。
現(xiàn)在Android的構(gòu)建工具換成了gradle,通過(guò)gradle,簡(jiǎn)單配置后就可以實(shí)現(xiàn)自動(dòng)打所有渠道包。

實(shí)現(xiàn)步驟:

1.按照umeng的要求,manifest文件中需要有

<meta-data
 android:name="UMENG_CHANNEL"
 android:value="${UMENG_CHANNEL_VALUE}" />

這段配置,value那里就是wandoujia,360之類(lèi)的渠道名稱(chēng),但是我們?cè)谶@里不會(huì)去寫(xiě)渠道名,寫(xiě)的是一個(gè)占位符,后面gradle編譯的時(shí)候會(huì)動(dòng)態(tài)的替換掉它。

2、在module(一般也就是app)的build.gradle的android{}中添加如下內(nèi)容:

productFlavors{
     wandoujia{
       manifestPlaceholders = [UMENG_CHANNEL_VALUE: "wandoujia"]
     }
     xiaomi{
       manifestPlaceholders=[UMENG_CHANNEL_VALUE: "xiaomi"]
     }
   }

productFlavors是android節(jié)點(diǎn)的一個(gè)自節(jié)點(diǎn)。你需要打什么渠道的包,就在這里按umeng的要求用渠道名給UMENG_CHANNEL_VALUE賦值。

3、優(yōu)化1:上面只是兩個(gè)渠道,如果有幾十個(gè)渠道,都這樣寫(xiě),重復(fù)的東西太多,觀察到每個(gè)渠道就是flavor的名稱(chēng),所以修改如下:

productFlavors{
 wandoujia{

 }
 xiaomi{

 }
 }
 productFlavors.all { flavor ->
 flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name]
 }

4、優(yōu)化2:上面經(jīng)過(guò)簽名打包后生成的apk的名稱(chēng)是有默認(rèn)命名規(guī)則的,如:xxx-xiaomi-release.apk 但是我們想包含版本信息如:xxx-xiaomi-release-1.0.apk,所以最終打包腳本如下:

productFlavors{
  wandoujia{

  }
  xiaomi{

  }
 }
 productFlavors.all { flavor ->
  flavor.manifestPlaceholders = [UMENG_CHANNEL_VALUE: name]
 }
 applicationVariants.all { variant ->
  variant.outputs.each { output ->
    def outputFile = output.outputFile
    if (outputFile != null && outputFile.name.endsWith('.apk')) {
      def fileName = outputFile.name.replace(".apk", "-${defaultConfig.versionName}.apk")
      output.outputFile = new File(outputFile.parent, fileName)
    }
  }
 }

4.獲取渠道

在代碼中我們可以通過(guò)讀取mate-data信息來(lái)獲取渠道,然后添加到請(qǐng)求參數(shù)中,獲取方法如下:

private String getChannel() {
  try {
    PackageManager pm = getPackageManager();
    ApplicationInfo appInfo = pm.getApplicationInfo(getPackageName(), PackageManager.GET_META_DATA);
    return appInfo.metaData.getString("UMENG_CHANNEL");
  } catch (PackageManager.NameNotFoundException ignored) {
  }
  return "";
}

5、執(zhí)行簽名打包
Android中打包的方式有哪些
這時(shí)候你去app/build/outputs/apk中就能看到自動(dòng)打好的渠道包了。

6、缺點(diǎn):

這樣的打包方式效率比較低下,如果是幾十個(gè)包還可以應(yīng)付,打一個(gè)包快的話(huà)需要十幾秒,慢的話(huà)需要幾分鐘不等,跟機(jī)器性能很有關(guān)系。

03、美團(tuán)多渠道打包原理:

把一個(gè)Android應(yīng)用包當(dāng)作zip文件包進(jìn)行解壓,然后發(fā)現(xiàn)在簽名生成的目錄下(META-INF)添加一個(gè)空文件不需要重新簽名。利用這個(gè)機(jī)制,該文件的文件名就是渠道名。這種方式不需要重新簽名等步驟,非常高效,但是貌似在Android7.0之后,Google為了增強(qiáng)簽名的安全性,采用了新的簽名規(guī)則,不是針對(duì)每個(gè)文件來(lái)進(jìn)行數(shù)字編碼,而是對(duì)zip包文件結(jié)構(gòu)編碼簽名后產(chǎn)生一個(gè)唯一的數(shù)據(jù)叫做apk signing block。如果修改了zip文件的任何模塊的內(nèi)容,APK Signing Block都會(huì)發(fā)生改變,從而無(wú)法再繞過(guò)簽名機(jī)制。

方法:

首先你需要去下載相關(guān)的工具:
Android中打包的方式有哪些

詳細(xì)步驟:

1、將要打包的apk放到PythonTool中
2、在PythonTool/info/channel.txt中寫(xiě)入需要的渠道,一個(gè)渠道占一行
3、雙擊執(zhí)行PythonTool/MultiChannelBuildTool.py文件(需要Python環(huán)境),就會(huì)生成渠道包
4、獲取渠道信息:將JavaUtil文件中的ChannelUtil.java拷貝到工程,調(diào)用ChannelUtil.getChannel即可獲取渠道.

優(yōu)缺點(diǎn):

優(yōu)點(diǎn):

這種打包方式速度非常快,900多個(gè)渠道不到一分鐘就能打完

缺點(diǎn):

1、google現(xiàn)在已經(jīng)修改了新的簽名規(guī)則,若使用新的簽名規(guī)則則無(wú)法使用(老的無(wú)所謂)。

2、一些不法的渠道商很容易通過(guò)工具修改渠道,如果一個(gè)渠道商,通過(guò)網(wǎng)絡(luò)劫持和篡改渠道的組合方式來(lái)獲取暴利,對(duì)于程序開(kāi)發(fā)者來(lái)說(shuō)可能會(huì)存在著巨大的經(jīng)濟(jì)損失

04、360多渠道打包:

apk文件本質(zhì)就是zip文件,利用zip文件“可以添加comment(摘要)”的數(shù)據(jù)結(jié)構(gòu)特點(diǎn),在文件的末尾寫(xiě)入任意數(shù)據(jù),而不用重新解壓zip文件,我們就可以將渠道信息寫(xiě)入摘要區(qū)

方法:

首先還是去下載相關(guān)工具:
Android中打包的方式有哪些

步驟:

1、將要寫(xiě)入渠道信息的apk放入MCPTool文件夾中
2、修改MCPTool.bat批處理文件,更改渠道和密碼(渠道信息為了安全需要加密)

3、將apk拖到MCPTool.bat上執(zhí)行,將會(huì)生成渠道包

4、修改MCPTool-check.bat中的密碼和MCPTool.bat中的密碼一致

5、將渠道包拖到MCPTool-check.bat上執(zhí)行,就可以檢查渠道信息是否正確

6、獲取渠道:將MCPTool.java添加到工程或者將MCPTool.jar導(dǎo)入工程,調(diào)用 MCPTool.getChannelId(this,”12345678”,”“) 第一個(gè)參數(shù)為context,第二個(gè)是密碼,第三個(gè)是默認(rèn)值。

優(yōu)缺點(diǎn):

優(yōu)點(diǎn):

1、5M的apk,1秒種能打300個(gè)
2、在下載apk的同時(shí),服務(wù)端可以寫(xiě)入一些信息,例如邀請(qǐng)碼,分享信息等

缺點(diǎn):

渠道信息也是很容易修改,雖然可以加密,只是提高了修改的門(mén)檻

看完上述內(nèi)容,你們對(duì)Android中打包的方式有哪些有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI