亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

android 二次打包完成apk多渠道打包的方法

 更新時(shí)間:2017年10月30日 09:18:42   作者:君莫醉  
本篇文章主要介紹了android 二次打包完成apk多渠道打包的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

本文介紹將渠道號(hào)寫(xiě)入assets文件里面,通過(guò)解壓apk修改assets里的文件,用Java代碼生成jarsigner腳本并運(yùn)行腳本二次打包的方式來(lái)獲取新的渠道包

此打包方式一個(gè)渠道包只需要5秒左右,可實(shí)現(xiàn)快速打渠道包

對(duì)于為了在assets獲取渠道號(hào)來(lái)打渠道包的方法,其實(shí)很簡(jiǎn)單,你只要知道apk里面裝的什么東西,就會(huì)了

將apk用壓縮方式解壓,你會(huì)得到像

這樣的文件列表,其中就有assets文件夾;當(dāng)然前提條件是你在項(xiàng)目中必須創(chuàng)建assets文件夾。既然有了這個(gè)文件夾,安卓里面又能通過(guò)代碼獲取這個(gè)文件夾里面的文件,并讀取文件:

  private static String getChannel(Context context){
    try {
      InputStream in = context.getAssets().open("qudao.txt");
      int size = in.available();
      byte[] buffer = new byte[size];
      in.read(buffer);
      in.close();
      String txt = new String(buffer, "utf-8");
      Log.d("qudaobiaoji:",txt);
      return txt;
    } catch (IOException e) {
      e.printStackTrace();
    }
    return "未知";
  }

那么接下來(lái)就只需要通過(guò)修改里面的文件,并重新打包,簽名來(lái)打渠道包了。

如何修改里面的文件,并打包簽名,我特地寫(xiě)了一個(gè)打包工具,通過(guò)java工程生成jar,通過(guò)命令行運(yùn)行jar讀取配置文件然后生成打包腳本,自動(dòng)運(yùn)行腳本進(jìn)行打包

介紹

在java工程中的入口是

main函數(shù),

 public static void main(String[] args) {}

以前一直不知道args是干嘛的,后來(lái)通過(guò)命令行傳入?yún)?shù),才知道args可以帶入命令行的參數(shù)

1.讀取配置文件:

通過(guò)文件的方式傳入要打的渠道包,及渠道包的名字,渠道號(hào)

讀文件操作很簡(jiǎn)單,就是通過(guò)流的形式,不多介紹,可以自行閱讀源碼

文件配置:

app_path=app-release_aligned_signed.apk;
keystore=ej_v3.jks;
keyAlias=ej_v3;
keyPassword=123456;
storePassword=123456;
contents=優(yōu)億,魅族;
apkname=youyi,meizu;

2.解壓apk文件

  1. 通過(guò)java代碼將apk解壓出來(lái)、
  2. 通過(guò)ZipFile來(lái)解壓文件
  3. 解壓完后刪除簽名文件

3.替換渠道號(hào)文件

獲取解壓后的assets路徑,并修改里面的渠道文件內(nèi)容,

        //------修改內(nèi)容
        String content = contents[i];
        String apkn = apkNames[i];
        buffer.setLength(0);
        String path = buffer
            .append(prefixName).append(ZipUtil.UPDATE_PATH_NAME).toString();
        System.out.println("path:"+path);
        br = new BufferedReader(new InputStreamReader(new FileInputStream(path),"UTF-8"));
        while ((br.readLine()) != null) {
          osw = new OutputStreamWriter(new FileOutputStream(path),"UTF-8");
          osw.write(content, 0, content.length());
          osw.flush();
        }

4.重新壓縮生成.apk文件,此文件是未簽名文件

ZipUtil.compress(prefixName,targetPath+"\\"+unsing+"\\"+apkn+"_unsin.apk");

5.生成簽名腳本內(nèi)容

復(fù)制代碼 代碼如下:

batStr+="jarsigner -verbose -keystore "+keystore+" -signedjar "+targetPath+"\\"+sing+"\\"+apkn+"_sin.apk "+targetPath+"\\"+unsing+"\\"+apkn+"_unsin.apk"+" "+keyAlias+"\n";

6.運(yùn)行簽名腳本

  public static void runbat(String batName) {
    String cmd = "cmd /c start "+ batName;// pass
    try {
      Process ps = Runtime.getRuntime().exec(cmd);
      ps.waitFor();
    } catch (IOException ioe) {
      ioe.printStackTrace();
    }
    catch (InterruptedException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
    }
    System.out.println("child thread donn");
  }

有興趣的同學(xué)可以看下源碼,在增加別的渠道的情況下不需要另外配置gradle參數(shù),直接修改配置文件,運(yùn)行腳本就行了

今天網(wǎng)上查了下jarsigner打包命令,發(fā)現(xiàn)可以直接在腳本中輸入密碼,可直接打包,不用反復(fù)輸入密碼
腳本:

jarsigner -verbose -keystore test.jks -storepass 123456 -keypass 123
456 -signedjar target\sing\youyi_sin.apk target\unsing\youyi_unsin.apk test

源碼地址:https://github.com/dengzhi00/ApkQuDao

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論