android 多aar上傳私人maven服務器


前言

為了精簡目前底層的基礎組件庫, 拆分出必要依賴項目(有一定精簡)和完全的依賴項目,
第一想法是在library上構建變種(Variant)版本, 一次發布所有的變種,在研究了一些相關的資料后,
最后完美解決

基礎部署到maven倉庫

我們可以通過gradle部署到遠程或者本地的maven倉庫,
首先添加maven插件, 然后我們通過updaloadArchives任務自動生成POM文件, 并打包部署到指定的倉庫中

  apply plugin: 'maven'  // 添加maven插件
  uploadArchives {
    repositories {
        mavenDeployer {
            repository(url: "maven倉庫地址")
            }
        }
    }

當然我們也可以通過authentication來添加服務器的認證信息, 也可以定義快照(snapshot)倉庫

apply plugin: 'maven'  // 添加maven插件
uploadArchives {
  repositories {
      mavenDeployer {
          repository(url: "maven倉庫地址"){
              authentication(userName: "yourUserName", password: "yourPsw")
              }
          snapshotRepository(url: "maven snapshot倉庫地址"){
              authentication(userName: "yourUserName", password: "yourPsw")
          }
      }
  }

POM文件的自定義

我們可以針對POM做自定義處理, 最常見的就是設置版本號等等

apply plugin: 'maven'  // 添加maven插件
uploadArchives {
  repositories {
      mavenDeployer {
          repository(url: "maven倉庫地址")
          }
          pom.groupId = "com.maven.test"
          pom.artifactId = "myLibrary"
          pom.version = "1.0.0"
          pom.packaging = "aar"
      }
  }

針對上面的設置, 我們依賴引用的就應該是

implementation "com.maven.test:myLibrary:1.0.0"

Maven默認每個項目只會處理一個artifact, 當我們library沒有設置productFlavor和buildType時, 默認上傳的是release的variant.
當我們兩個variant代碼不同, 依賴不同時, 需要生產不同的POM進行上傳,這種情況下我們需要顯示聲明每個artifact, 并針對每個POM進行自定義上傳.
在這方面我們可以分別參考MavenDeployerMavenPom開放的API

// 上略
mavenDeployer {
            repository(url: "倉庫地址")
            android.libraryVariants.all {variant->
                def isFlavor = !variant.flavorName.isEmpty()
                def _name = "${variant.name}"
                // 生成多個pom
                addFilter(_name){artifact, file->
                    true
                }
                // 對應pom屬性設置
                pom(_name).artifactId = project.archivesBaseName + "-" + _name
                pom(_name).version = "1.0.0"
                pom(_name).groupId = "com.maven.test"
                pom(_name).packaging = 'aar'
                // 自定義pom的依賴集
                pom(_name).withXml{
                    def root = asNode()
                    def depsNode = root["dependencies"][0] ?: root.appendNode("dependencies")
                    def addDep = {
                        if (it.group == null) return // Avoid empty dependency nodes
                        def dependencyNode = depsNode.appendNode('dependency')
                        dependencyNode.appendNode('groupId', it.group)
                        dependencyNode.appendNode('artifactId', it.name)
                        dependencyNode.appendNode('version', it.version)
                        if (it.hasProperty('optional') && it.optional) {
                            dependencyNode.appendNode('optional', 'true')
                        }
                    }
                    // 添加基本依賴
                    configurations.api.allDependencies.each addDep
                    configurations.implementation.allDependencies.each addDep
                    // 添加特殊依賴
                    if (isFlavor) {
                        configurations["${_name}Implementation"].allDependencies.each addDep
                        def flavorName = variant.flavorName
                        configurations["${flavorName}Implementation"].allDependencies.each addDep
                        configurations["${_name}Api"].allDependencies.each addDep
                        configurations["${flavorName}Api"].allDependencies.each addDep
                    }
                }

            }
        }

相關demo可以看這里

依賴對應的組件庫

在成功發布后, 我們倉庫內容應該如下圖


image.png

假設我們的flavor分別為full和simple,當我們去依賴的時候, 就可以通過

fullReleaseImplementation "com.maven.test:libraryNameFullRelease:1.0.0"
fullDebugImplementation "com.maven.test:libraryNameFullDebug:1.0.0"
simpleReleaseImplementation "com.maven.test:libraryNameSimpleRelease:1.0.0"
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容