Ant是一個很好的跨平台構建工具,特別是對於Java項目,這裡使用它對Android工程進行自動化構建可以得到非常大的便利。一般來說對Android工程進行構建主要有以下幾個步驟:
- 使用aapt來編譯工程產生R.java;
- 使用aapt來對工程所需用的資源進行打包;
- 轉換並編譯AIDL檔案;
- 編譯Java源檔案並產生.class;
- 轉換並壓縮.class檔案成.dex檔案;
- 使用aapt打包產生未簽名的apk包;
- 使用jarsigner對apk包簽名並得到最終的發布包。
關於這些步驟所需要的實現細節就不再詳述了(網格上各種版本,大多都能使用),這裡主要說一下對於多個渠道情況下的apk打包。所謂的多個渠道一般來說就需要對每個要發布的渠道版本進行一次上述系列操作,而這多個渠道的差異通常是可以公用出來的一些配置資訊,比如渠道的編號,渠道的資訊等。如此一來就可以將其統一組織到一個設定檔裡邊,在進行流程前使用ant的功能對其進行具體的渠道設定就可以了,比如:
<replace file="${pathsettingfile}" token="Ant_PathID" value="${_PathID}"/><replace file="${pathsettingfile}" token="Ant_PathName" value="${_PathName}"/>
其中的_PathID,_PathName均為在ant環境中定義的變數,其可以是直接從cmd傳入或通過其它方式來賦值。這樣在進行後續的編譯時間就可以直接得到該渠道下的版本。
此外,還可以將所有渠道的資訊統一配置於一xml之中,在進行構建時直接從其中讀入各個渠道的資訊並賦值到如上的_PathID、_PathName中即可,可以用如下代碼方便實現(其中涉及xmltask在ant中的使用,這個可以參考ant的相關資料):
<target name="main"> <taskdef name="xmltask" classname="com.oopsconsultancy.xmltask.ant.XmlTask"/> <echo>Starting....</echo> <xmltask source="Paths.xml"> <call path="/PathList/PathDetail[@enabled='true']" target="build"> <param name="_PathID" path="ID/text()"/> <param name="_PathName" path="Name/text()"/> </call> </xmltask> </target>
對應的渠道配置xml則基本上如下所示(當然其中可以置入更多的資訊)
<?xml version="1.0" encoding="UTF-8"?><PathList> <PathDetail name="" enabled="true"> <ID>11111</ID> <Name>Path_0</Name> </PathDetail> <PathDetail name="" enabled="true"> <ID>22222</ID> <Name>Path_1</Name> </PathDetail></PathList>
此外,使用Ant的自動化構建還可以實現另外一個重要用途,對asset中的涉密檔案進行保護。這裡有一個簡單的例子,比如asset中有一些檔案對使用者可視,但卻不希望被使用者修改,這種情況下就可以在構建中加入一個檔案校正的階段,首先將要保護的檔案計算出對應的MD5簽名,之後再將此簽名寫入到程式碼中並進行編譯構建,在程式運行時使用此簽名進行校正,如果該簽名不匹配那就意味著被使用者修改後進行了重新的打包,此時程式就可以有相應的操作,這樣就可以在一定程式上防止使用者對發布的Apk包進行重新pack並運行。