当前位置:   article > 正文

利用 Gitlab 搭建 Maven仓库_gitlab搭建maven仓库

gitlab搭建maven仓库
如果公司服务器资源充足,采用Nexus 搭建一个Maven库。这样整个Maven库的管理会更合理和有效一些。

前言

打算利用公司已有的Gitlab代码管理库。实现maven仓库的搭建。

PS:如果公司服务器资源充足,采用Nexus 搭建一个Maven库。这样整个Maven库的管理会更合理和有效一些。

目标

结束aar和jar文件乱发的历史,使用implementation 引用。

如果在Glilab将项目配置为公共public权限。那么外部其他客户也可以使用maven仓库了。

实现步骤

1、打包配置

Android Studio 环境版本

Android Studio 4.2.1
build:gradle:4.2.1

将需要打包成jar或者aar的项目配置maven 脚本

新建一个:gitlab.gradle文件 和项目build.gradle同一级目录下创建。

并添加下面代码:

apply plugin: 'maven'

uploadArchives {
    repositories.mavenDeployer {
        def mavenDirPath = file('../maven') //  相对地址。 编译后的代码将会存在父目录的maven文件夹下。
        def mavenDirPath =  file('D:\\appmaven')  //绝对路径,编译后的代码将会存在 D盘的appmaven文件夹下。
        repository(url: "file://${mavenDirPath.absolutePath}")
        pom.project {
            groupId "cn.zinyan.demo" // 包名
            artifactId "Key" // module的名字
            version '1.1.1'// 版本号
            //配置完毕后,包名决定地址中的 第一项,artifactId 决定了第二项,version 决定了第三项版本号
            //implementation 'cn.zinyan.demo:Key:1.1.1'
        }
    }
}

//  如果不想生成 javadoc.jar 和 sources.jar 库以下代码可以省略
def sourceDirs
if (project.hasProperty("android")) {
    sourceDirs = android.sourceSets.main.java.srcDirs
}else {
    sourceDirs = sourceSets.main.java.srcDirs
}

task javadocs(type: Javadoc) {
    source = sourceDirs
}
//生成doc
task javadocsJar(type: Jar) { 
      
//     classifier='javadoc'  //老版本写法, 现在已经过期了。建议使用下面的
    archiveClassifier.set('javadoc')
    from javadocs.destinationDir
}
//生成sources
task sourcesJar(type: Jar) {
    //     classifier='sources'//老版本写法, 现在已经过期了。建议使用下面的
    archiveClassifier.set('sources')
    from sourceDirs
}

artifacts {
    archives javadocsJar
    archives sourcesJar
}

在build.gradle 文件中引用gitlab.gradle 文件。

添加方式:apply from: 'gitlab.gradle'

然后我们可以在右侧的Gradle面板的Tasks->upload->uploadArchives 指令

点击执行该指令,就可以在本地生成相应编译后的代码了。

上面的指令直接支持:aar库和jar库的编译。 系统会根据你的lib的类型。自动打相应的文件。

2、上传代码

直接通过gi将执行编译后的全部aar,和jar等数据上传就可以了。

包括aven-metadata.xml等文件,pom等文件,javadoc等文件,sources等文件。

3、使用gitlab库的maven

(1)maven是公共的

如果你的GitLab上的maven仓库项目是公共的。那么maven 就是公共的

其他人调用,只需要该maven库的地址即可

allprojects {
    repositories {
        maven {
            url "https://你的仓库的地址+直接到项目名/分支/"
        }
}

如果该项目是你自己的。而不是组里面的。那么Group名称就得换成你的用户名了。

有一个很简单的方法。

访问你的gitLab库,打开我们提交的一个xml文件。例如pop.xml文件。

在浏览器中,从https开始一直到你的包名称截止,这一段地址就是我们需要配置到maven上的url地址。后面的包名路径,IDEA会自动帮我们补上并更新了
(2)maven是私有的

如果你的GitLab 是私有的。只想部分人可以使用。

需要在maven 地址导入的位置,添加相应的访问账号和Token了。

可以参考文章 利用Gitlab仓库搭建私有Maven仓库 - 知乎 (zhihu.com)

4、使用gitee库的样例

例如我在gitee上搭建的一个简单的maven仓库。

allprojects {
    repositories {
        maven{
            url 'https://gitee.com/zinyan/maven/raw/master/'
        }
}
implementation 'com.zinyan.util:general:1.0.0'

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/130579
推荐阅读
相关标签
  

闽ICP备14008679号