日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關咨詢
選擇下列產(chǎn)品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
AndroidSDK開發(fā)—發(fā)布使用踩坑之路

前言

在阜陽等地區(qū),都構建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務理念,為客戶提供網(wǎng)站設計、成都做網(wǎng)站 網(wǎng)站設計制作按需設計網(wǎng)站,公司網(wǎng)站建設,企業(yè)網(wǎng)站建設,品牌網(wǎng)站建設,成都全網(wǎng)營銷推廣,外貿(mào)營銷網(wǎng)站建設,阜陽網(wǎng)站建設費用合理。

在 Android 開發(fā)過程中,有些功能是通用的,或者是多個業(yè)務方都需要使用的。

為了統(tǒng)一功能邏輯及避免重復開發(fā),因此將該功能開發(fā)成一個 SDK 是相當有必要的。

背景

剛好最近自己遇到了類似需求,在開發(fā)完 SDK 之后,集成到項目或者提供給別人的時候遇到了一些坑,這里分享一下,以避免其他需要開發(fā) SDK 的開發(fā)者們重復踩坑。

文章要說明的內(nèi)容如下:

  1. 集成方式對比
  2. AAR 集成方式的一些坑
  3. 使用 maven publish 和 maven 將 SDK 推送到 maven 倉庫的區(qū)別
  4. Tips
  5. 總結

集成方式對比

SDK 開發(fā)完成之后,需要提供一種集成方式讓其他人可以使用。

集成方式這邊認為大概有 3 種。

1. 提供 Module

這種集成方式把整個 SDK 的源碼都提供給其他人。

  • 優(yōu)點:沒有什么坑,只要自己測試沒問題,別人一般可以直接使用。
  • 缺點:后續(xù)如果有更新,需要全量給別人進行替換。

而且項目里面如果同時引用多個Module,項目結構會增加很多代碼文件。

還有可能一不小心就更改了 SDK。

因為源碼可以直接修改,沒有任何保護。

2. 提供 AAR 文件

這種集成方式是把 SDK 編譯之后提供 AAR 文件給其他人。

  • 優(yōu)點:只有一個文件,不需要給到具體源碼。
  • 缺點:某種情況下有坑,下面會講到。另外更新 SDK 不方便,每次更新需要用戶進行 AAR 文件替換。

3. 推送到倉庫(這里以 MAVEN 倉庫為例)(推薦)

這種集成方式是把 SDK 編譯之后的 AAR 文件推送到倉庫,后續(xù)可以通過 implementation 或者 api(舊版本 Gradle 為 compile)引用。

  • 優(yōu)點:集成方便,跟第三方庫集成類似,方便開發(fā)者。而且有版本管理。
  • 缺點:maven publish 有個坑。見下文分析。

表格對比如下:

集成方式優(yōu)點缺點提供 Module沒有坑維護麻煩,沒有代碼保護提供 AAR 文件只有一個文件有坑,更新麻煩推送到倉庫集成方便,版本管理maven publish有個坑

AAR 集成方式的一些坑

一般 SDK 開發(fā)是封裝一些功能方便調(diào)用,因此比較少在 Module 里面引入第三方庫。這種情況下使用 AAR 集成是沒有太大問題的。

然而,當你的 SDK 中引入第三方庫,比如 Retorfit 之類的庫時(不是直接引入 jar 包或者 aar 包),這個時候你使用 AAR 集成,運行到對應代碼時會提示 java.lang.NoClassDefFoundError 錯誤。這個時候你

[[252825]]

明明 Module 運行沒問題,怎么 AAR 就報錯了。

如果你嘗試在項目里面將 SDK 用到的第三方庫再引入一遍,就會發(fā)現(xiàn)程序沒報錯了。

因此我們可以得出結論:

  • AAR 不能傳遞第三方依賴

別慌,方法總比問題多。

我們可以通過將 SDK 推送到倉庫的方式來解決這個問題。

推送倉庫有很多,比如開源的 jcenter 之類的。

這邊考慮有些 SDK 是給公司內(nèi)部使用的,因此以 maven 為例進行講解。

使用 maven publish 和 maven 將 SDK 推送到 maven 倉庫的區(qū)別

maven publish 其實是 maven 的一個升級。

所以一般優(yōu)先采用 maven publish。

這邊項目已經(jīng)使用了 maven publish 了,所以這邊一開始也是使用 maven publish。

結果坑來了。

發(fā)現(xiàn)出現(xiàn)和 AAR 一樣的錯誤,依賴不能傳遞。

這,趕緊看一眼 pom 文件(跟 AAR 同級目錄),發(fā)現(xiàn)真的沒有依賴。

查了一下網(wǎng)上資料。發(fā)現(xiàn)

  • https://discuss.gradle.org/t/using-the-maven-publish-plugin-no-dependencies-in-pom-xml/7599

有一個提問

[[252826]]

當然應該有對應的處理方式,但是由于項目時間需求比較緊,不想花太多時間,因此暫時沒有查找解決方式。

如果有朋友知道,可以留言,后續(xù)有空研究,有解決方法也會更新。

因此這里不展開討論 maven publish 的集成方式。

最后查閱資料使用了 maven 的推送方式。

那么如何使用呢?

1. 先使用本地倉庫,確保沒問題之后再使用遠程的

在 Module 的 build.gradle 文件中添加如下代碼:

 
 
 
 
  1. apply plugin: 'maven' //指定使用 maven 
  2. uploadArchives { 
  3.  repositories { 
  4.  mavenDeployer { 
  5.  pom.groupId = "com.maven.demo" //包名 
  6.  pom.artifactId = "login" //SDK 功能,自定義一個即可 
  7.  pom.version = "0.0.1" //版本號 
  8.  repository(url: "file://localhost/Users/用戶名/Library/Android/sdk/extras/android/m2repository/") //用戶名替換為自己的機器名,本地地址 
  9.  } 
  10.  } 

執(zhí)行 uploadArchives 任務就可以上報了。

然后到上面 url 指定的目錄或者通過瀏覽器打開可以看到上傳的相關文件。

查看 pom 文件可以看到依賴都在上面。

2. 使用遠程倉庫,對上面略做修改。

 
 
 
 
  1. apply plugin: 'maven' //指定使用 maven 
  2. uploadArchives { 
  3.  repositories { 
  4.  mavenDeployer { 
  5.  pom.groupId = "com.maven.demo" //包名 
  6.  pom.artifactId = "login" //SDK 功能,自定義一個即可 
  7.  pom.version = "0.0.1" //版本號 
  8.  repository(url: "網(wǎng)址") { 
  9.  authentication(userName: "用戶名", password: "密碼") 
  10.  } 
  11.  } 
  12.  } 

其中網(wǎng)址、用戶名和密碼記得分別替換。

別人需要使用時只需要在 Module 添加如下:

 
 
 
 
  1. implementation 'com.maven.demo.login.0.01' 

所以倉庫的組成就是pom.groupId+pom.artifactId+pom.version

Tips:

1. SDK 開發(fā)可能遇到同一個版本比如 0.0.1 在發(fā)布之前經(jīng)常需要修改的情況。

這個時候如果你把修改后的 SDK 推送到遠程,可能本地項目用的還是舊的內(nèi)容。

這種時候有兩個處理方式。

  • 第一個,更新版本號,修改依賴新版本。
  • 第二個,執(zhí)行下面命令,強制從遠程拉取,不使用緩存。
 
 
 
 
  1. ./gradlew build --refresh-dependencies 

2. 使用遠程倉庫時,一般用戶名和密碼都不會直接推送到代碼倉庫,可能會放到構建機。

這個時候需要使用類似于 local.properties 的外部文件來存放。

這個時候有個坑需要提醒一下,就是在 local.properties 定義比如maven_user_name=username,千萬記得不要加雙引號,否則會出現(xiàn)認證失敗,出現(xiàn)下面提示:

 
 
 
 
  1. Received status code 401 from server: Unauthorized 

3. 使用 maven 的形式如何指定是 debug 還是 release?

通過在 android 塊里面添加

 
 
 
 
  1. android { 
  2.  defaultPublishConfig "release" 

可以指定。

通過查看 Module 的 build/outputs/aar 可以看到 aar 包。

通過查看 Module 的 build/poms/pom-default.xml 可以看到本地 pom 文件。

4. 有些開發(fā)者如果按照上面操作之后還是出現(xiàn) java.lang.NoClassDefFoundError 錯誤,可以嘗試下面操作:

修改

 
 
 
 
  1. implementation 'com.maven.demo.login.0.01'  

 
 
 
 
  1. implementation 'com.maven.demo.login.0.01' { 
  2.  transitive = true 

總結

  • 1. SDK 開發(fā)完成之后發(fā)布給其他人使用最好放到遠程倉庫(比如 maven)2. 如果出現(xiàn) SDK 引入的第三方庫沒有找到的錯誤,記得到倉庫看下 pom 文件是否有對應依賴

分享文章:AndroidSDK開發(fā)—發(fā)布使用踩坑之路
URL網(wǎng)址:http://www.dlmjj.cn/article/djscoso.html