当前位置: 首页 > article >正文

Android上传aar到本地仓

由于最近项目结构变动,经常需要将module项目打成aar供其他项目引用,在使用过程中,遇到本地module项目上传maven后其引用的aar其他项目需要重复引入的问题,所以在此记录下,将本地module项目打包aar上传本地仓和第三方aar上传本地仓的方法.

一、将本地module项目打包成aar上传到本地仓

1.在项目根目录下新建mavenConfig.properties文件,存放本地仓配置信息

NEXUS_REPOSITORY_URL = http://localhost:8081/repository/maven-local/
NEXUS_USERNAME = admin
NEXUS_PASSWORD = admin123

2.在项目根目录新建maven_deployer.gradle,用于保存aar打包任务和配置pom信息

2.1 Gradle 7.0以下时,打包aar上传需要使用插件

apply plugin: 'maven'

所以maven_deployer.gradle内容如下

def pomGroupId = 'com.dyj.test'
def pomArtifactId = this.getName()
def pomVersion = '1.0.0'
def pomDescription = "upload aar test ${pomVersion},测试aar打包"

apply plugin: 'maven'
uploadArchives {
    repositories {
        mavenDeployer {
            //从本地文件读取仓库账号和密码
            File propFile = new File('mavenConfig.properties')
            if (propFile.canRead()) {
                Properties props = new Properties()
                props.load(new FileInputStream(propFile))

                if (props != null && props.containsKey('NEXUS_REPOSITORY_URL')
                        && props.containsKey('NEXUS_USERNAME')
                        && props.containsKey('NEXUS_PASSWORD')) {
                    def NEXUS_REPOSITORY_URL = props['NEXUS_REPOSITORY_URL']
                    def NEXUS_USERNAME = props['NEXUS_USERNAME']
                    def NEXUS_PASSWORD = props['NEXUS_PASSWORD']

                    repository(url: NEXUS_REPOSITORY_URL) {
                        authentication(
                                userName: NEXUS_USERNAME,
                                password: NEXUS_PASSWORD
                        )

                        // 上传名称 版本号 介绍 等
                        pom.project {
                            name pomArtifactId
                            version pomVersion
                            description pomDescription
                            artifactId pomArtifactId
                            groupId pomGroupId
                            packaging 'aar'
                        }
                    }
                } else {
                    println '请确认maven配置文件有没有问题'
                }
            }
        }
    }
}

2.2 Gradle 7.0以上时,打包aar上传需要使用插件

apply plugin: 'maven-publish'

所以maven_deployer.gradle内容如下

def pomGroupId = 'com.dyj.test'
def pomArtifactId = this.getName()
def pomVersion = '1.0.0'
def pomDescription = "upload aar test ${pomVersion},测试aar打包"

apply plugin: 'maven-publish'
afterEvaluate {
    publishing {
        publications {
            release(MavenPublication) {
                from components.release
                groupId = pomGroupId
                artifactId = pomArtifactId
                version = pomVersion
                description = pomDescription
            }
        }

        repositories {
            maven {
                Properties versionProperties = new Properties()
                File proFile = project.rootProject.file('mavenConfig.properties');
                if(proFile.canRead()){
                    InputStream versionIs = proFile.newDataInputStream()
                    versionProperties.load(versionIs)
                    versionIs.close()
                    allowInsecureProtocol true  // 如果PUBLISH_URL是http,此处必须为true,如果是https,则可以删除此项
                    name = "Nexus"  // 配置后在Gradle > Tasks > publishing 下会显示对应的名称,容易区分
                    url = uri(versionProperties.NEXUS_REPOSITORY_URL)
                    credentials {
                        username = versionProperties.NEXUS_USERNAME
                        password = versionProperties.NEXUS_PASSWORD
                    }
                    println("maven " + versionProperties.NEXUS_REPOSITORY_URL)
                    println("maven " + versionProperties.NEXUS_USERNAME)
                    println("maven " + versionProperties.NEXUS_PASSWORD)
                }else {
                    println("maven properties 属性文件不存在")
                }
            }
        }
    }
}

3.在需要打包aar的module项目的build.gralde中添加引用maven_deployer.gradle

apply from: "${rootProject.rootDir}/maven_deployer.gradle"

4.执行gradle 任务,即可将module打包成aar上传本地仓

4.1 使用2.1方式引入maven插件的,可以在module的gradle的task中找到uploadArchives,双击执行,或者直接在Terminal中运行

gradle uploadArchives

gradle uploadArchives

4.2 使用2.2方式引入maven-publish插件的,可以在module的gradle的task中找到publish,双击执行,或者直接在Terminal中运行

gradle publish

gradle publish

二、将第三方aar上传到本地仓

为了方便module项目打包aar,module项目可能引入第三方aar,每次打包完module项目后其他项目还需要主动引入第三方aar比较麻烦,所以将第三方aar上传一份到本地仓.

1.将第三方aar以module项目方式添加到工程中,在对应module的build.gradle中,添加配置

configurations.maybeCreate("default")
artifacts.add("default",file('JsBridgeLib-release.aar'))

目录格式如下:
将aar以项目方式引用

2.和普通module项目相同的方式,在项目的settings.gradle中引入各aar的module项目

include ':LocalRepo:AlipaySdk_aar'
include ':LocalRepo:Apppaysdk_aar'
include ':LocalRepo:JsBridgeLib_aar'

3.由于第三方aar已经是生成好了的aar包,所以我们只需要执行上传maven的时候指定需要上传的Publishing artifacts文件即可,所以将上面上传maven_deployer.gradle中稍微修改下,如下

def pomGroupId = 'com.dyj.third.lib'
def pomArtifactId = 'JsBridge'
def pomVersion = '1.0.0'
def pomDescription = "upload JsBridge ${pomVersion},JsBridge sdk"

apply plugin: 'maven-publish'
afterEvaluate {
    publishing {
        publications {
            release(MavenPublication) {
                groupId = pomGroupId
                artifactId = pomArtifactId
                version = pomVersion
                description = pomDescription

                artifact file("JsBridgeLib-release.aar")
            }
        }

        repositories {
            maven {
                Properties versionProperties = new Properties()
                File proFile = project.rootProject.file('mavenConfig.properties');
                if(proFile.canRead()){
                    InputStream versionIs = proFile.newDataInputStream()
                    versionProperties.load(versionIs)
                    versionIs.close()
                    allowInsecureProtocol true  // 如果PUBLISH_URL是http,此处必须为true,如果是https,则可以删除此项
                    name = "Nexus"  // 配置后在Gradle > Tasks > publishing 下会显示对应的名称,容易区分
                    url = uri(versionProperties.NEXUS_REPOSITORY_URL)
                    credentials {
                        username = versionProperties.NEXUS_USERNAME
                        password = versionProperties.NEXUS_PASSWORD
                    }
                    println("maven " + versionProperties.NEXUS_REPOSITORY_URL)
                    println("maven " + versionProperties.NEXUS_USERNAME)
                    println("maven " + versionProperties.NEXUS_PASSWORD)
                }else {
                    println("maven properties 属性文件不存在")
                }
            }
        }
    }
}

4.执行同上的gradle 任务,即可将第三方aar上传本地仓

参考资料
https://developer.android.com/studio/publish-library/upload-library?hl=zh-cn


http://www.kler.cn/a/7552.html

相关文章:

  • Python教程笔记(2)
  • 大模型基础BERT——Transformers的双向编码器表示
  • 算法魅力-二分查找实战
  • springboot 文件高效上传
  • Uniapp踩坑input自动获取焦点ref动态获取实例不可用
  • Molecular signatures database (MSigDB) 3.0
  • MongoDB 插入文档
  • 考勤、充电,绑身份,你的人员定位系统就缺它了!
  • 大数据 | 实验一:大数据系统基本实验 | 熟悉常用的HDFS操作
  • scroll-view不能滚动问题
  • RK3588平台开发系列讲解(同步与互斥篇)信号量介绍
  • Javscript字符串的常用方法有哪些?
  • Python 进阶指南(编程轻松进阶):七、编程术语
  • Python 进阶指南(编程轻松进阶):二、环境配置和命令行
  • 【QT】在公司为了统一代码的风格,那如何在Qt Creater中进行设置
  • ROS实践08 订阅乌龟位姿C++
  • 人人都是数据分析师-数据分析之数据图表可视化(下)
  • 每日一问-ChapGPT-20230406-中医基础-脉诊
  • chatGPT教程
  • 清理MySQL 慢sql日志的方法 flush log/table 注意事项
  • 【ES实战】ES集群节点迁移与缩容补充说明
  • Onedrive for Business迁移方案 | 分享一
  • SQL是什么?它能做什么?SQL的基本书写规则
  • Java面向对象多态
  • 定语从句的省略
  • 【Go基础】一篇文章带你了解 — 异常处理