关于安卓artifactory本地仓库搭建(一)

前提:

对于一个项目,有一个庞大的三方sdk依赖情况下,每次更新依赖版本,都会重新下载一次依赖,这样对于开发者来说,是极其不友善的。
因此,就有了一个本地仓库的概念。

使用artifactory有什么好处:
(1)加快开发效率
(2)加快开发效率
(3)加快开发效率

当然,artifactory的好处远远不止这么多,本文简述如何搭建一个本地artifactory仓库并且在androidstudio中使用,更多相关的功能将会日后补充。

准备

(1)win10电脑
(2)androidstudio(博主用的是4.2.2版本)
(3)jdk1.8
(4)artifactory安装文件(博主用的是6.23.42版本)

开始
启动artifactory

对于artifactory,这里提供一个下载链接link
从这个链接下载即可。
下载后,解压,打开bin目录,管理员身份运行artifactory.bat
等待提示,运行后即可在浏览器输入访问地址。
bat运行图片

浏览器输入http://localhost:8081/即可访问。初始账号密码admin,password。

参数设置

这里,先修改artifactory的配置。

配置运行匿名访问

点击左侧菜单,进入General Security Configuration,选择Allow Anonymous Access
配置运行匿名访问

文件上传大小限制

选择General Configuration进入设置即可
文件上传限制

配置仓库

仓库描述

本地仓库

点击local,然后进入配置页面,这里我们新建一个,名字叫做
android_local 的仓库。保存。

远程仓库

然后,点击remote,配置远程仓库。
阿里云远程仓库参考
这里“远程仓库”的定义 ,就是你项目中需要的远程依赖链接,举个例子,项目中build文件配置如下:

//        maven { url 'https://maven.aliyun.com/nexus/content/groups/public/' }
//        maven { url 'https://maven.aliyun.com/repository/jcenter' }
//        maven { url 'https://maven.aliyun.com/repository/google'}
//        maven { url 'https://maven.aliyun.com/repository/gradle-plugin'}
//        maven { url 'https://maven.aliyun.com/repository/public'}
//        maven { url 'https://www.jitpack.io' }

那么,我们就要配置对于的远程依赖,选择maven,输入名字,输入仓库链接,点击保存即可。
远程仓库配置

!!!请根据项目中仓库链接实际数量进行添加!!!

虚拟仓库

点击Virtual,建立一个名字叫做
android_group 的虚拟仓库,然后把之前的本地仓库,远程仓库全部导入到该仓库,点击保存。

最后,返回Artifact Repository Browser,可以看到仓库列表如下:
仓库列表

导入gradle到本地仓库

构想一下,androidstudio使用gradle的时候,是怎样进行构建的?没错,就是使用本地下载好的gradle进行构建,所以我们得提供一个gradle链接给androidstudio,此外还得配置一个链接,用于统一识别三方依赖,统一下载。
涉及到的文件,就是项目中的:
(1)项目根目录下的build.gradle文件
(2)项目中gradle文件夹中的gradle-wrapper.properties文件

好,下面先导入:
回到了Artifact Repository Browser页面,点击android_local,然后界面右上角,点击deploy上传一个gradle文件。
gradle下载链接
直接导入即可,截图如下:
导入gradle到本地仓库
这时候,刷新页面,会发现多出了一个导入的gradle.zip文件了
导入后的仓库结构图
对于repository path,就是我们项目中需要导入的gradle链接。

至此,已经完成了全部的artifactory的全部配置。
现在,返回到我们的androidstudio进行配置

androidstudio配置
(一)

首先,找出项目根目录下的build.gradle文件
修改依赖如下:

buildscript {
    repositories {
//        mavenCentral()
//        maven { url 'https://maven.aliyun.com/nexus/content/groups/public/' }
//        maven { url 'https://maven.aliyun.com/repository/jcenter' }
//        maven { url 'https://maven.aliyun.com/repository/google'}
//        maven { url 'https://maven.aliyun.com/repository/gradle-plugin'}
//        maven { url 'https://maven.aliyun.com/repository/public'}
//        maven { url 'https://www.jitpack.io' }
//        allowInsecureProtocol true
        maven { url 'http://localhost:8081/artifactory/android_group/' }
    }
}

allprojects {
    repositories {
        // 支付宝 SDK AAR 包所需的配置
//        mavenCentral()
//        maven { url 'https://maven.aliyun.com/nexus/content/groups/public/' }
//        maven { url 'https://maven.aliyun.com/repository/jcenter' }
//        maven { url 'https://maven.aliyun.com/repository/google'}
//        maven { url 'https://maven.aliyun.com/repository/gradle-plugin'}
//        maven { url 'https://maven.aliyun.com/repository/public'}
//        maven { url 'https://www.jitpack.io' }
//        allowInsecureProtocol true
        maven { url 'http://localhost:8081/artifactory/android_group/' }
    }
}

可见,maven仓库地址 ,是直接替换成为了我们本地的地址:
http://localhost:8081/artifactory/android_group/–虚拟仓库地址

(二)

配置gradle-wrapper.properties
内容如下图:

#Sat Apr 02 11:28:11 CST 2022
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
#distributionUrl=https\://services.gradle.org/distributions/gradle-6.5-all.zip
distributionUrl=http://localhost:8081/artifactory/android_local/gradle-6.5-bin.zip

可以看到,我们修改了distributionUrl的地址为我们上传到本地仓库的gradle.zip文件地址

至此,已经全部配置完成了,试着跑一下项目看看吧。
ps:若有报错,多clean几次后重新编译即可,若是build.gralde报https的问题,
则需要额外声明allowInsecureProtocol。

that’s all--------------------------------------------------------------------------------------

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值