gradle配置(gradle配置maven仓库)
本篇文章给大家谈谈gradle配置,以及gradle配置maven仓库对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
本文目录一览:
- 1、【Gradle深入浅出】——Gradle配置(一)
- 2、gradle 配置 nexus repository
- 3、Gradle之全局配置
- 4、Mac安装Gradle及配置
- 5、gradle代理设置
- 6、Linux下Nexus 3私服配置及gradle配置使用
【Gradle深入浅出】——Gradle配置(一)
1.【Gradle深入浅出】——初识Gradle
2.【Gradle深入浅出】——Gradle基础概念
3.【Gradle深入浅出】——Android Gradle Plugin 基础概念
4.【Gradle深入浅出】——Gradle配置(一)
5.【Gradle深入浅出】——Gralde配置(二)
前面三篇博客讲解了Gradle的基础概念,看完前面三篇博客我们应该对于Gradle都有了一个基础的认知,知道了文件的作用,Gradle的基本构成,本篇博客开始就开始进入Gradle的学习,首先讲解的是Gradle的配置,Gradle配置应该是我们日常开发中必不可少的技能,平时的打包,编译等等都需要熟悉Gradle的配置。
我们知道Gradle都关于属性配置有两个文件, local.properties 和 gradle.properties ,这两个文件的实质都是生成Java的 Properties 对象,所以要属性这两个文件的作用,首先要属性下 Properties 类。
我们首先来看下这个类的基本上结构。
看完这个我们应该就有一个大体的认识了, Properties 本质就是一个HashTable,支持设置默认属性,其他的没啥区别,哪我们看下 Properties 如何读取文件呢
可以看到 Properites 给我们提供了三个加载文件的方式,所以这里我们也可以得出一个结论, 使用 Properties 不是必须使用 .properties 格式的文件。
哪可能有人要问了,为啥这里的配置都使用properties格式的文件呢?
我猜测可能是复用Spring Boot中的支持的配置文件,Spring Boot中支持三种格式核烂培的配置文件 YAML,XML,Properties ,具体的差异这里就不展开讲解了。
我们可以理解为 .properties 就是类似于json的一套配置文件格式,IDE对于这类文件有特殊的支持,比如注释等语法,做了统一的规范
Properties文件的格式规范
有了对于Properties类的理解,我们在来看local.properties文件,理解起来就方便类许多,前面几篇博客已经提到了 local.properties 是Studio自动生成的一个本地配置文件,并且不会提交到远端,是我们自己本地的配置改唯文件,常见的配置如下:
既然是配置文件,那么如何在 local.properites 中定义全局变量,然后在build.gradle中读取呢?比如我们的maven上传需要用户的姓名密码,每个人的都不一样,所以可以放到local.propertiest文件中
和前面介绍的一样,我们只需要在local.properties中定义变量,然后在gradle中读取变量只需要生成Properties类来进行读取文件。
同样的这也是一个Properties类型的文件,但这个文件主要是配置和Gradle自身相关的配置内容的,接下来聊聊他的几个作用:
这里主要是配置本项目在使用Gradle进行编译时的配置,比如虚拟机堆栈配置(常见的编译速度优化就在这里配置)
所以看到上面的定义后,我们就可以理解常见的“编译速度优化”的配置的大概意思
除了刚才说的这个历基文件用于配置gradle属性,这个文件还可以用于配置系统属性和android属性
并且可以区分配置不同的项目的配置
1、单项目gradle使用代理:gradle/wrapper/gradle-wrapper.properties
2、全局gradle使用代理:userdir/.gradle/gradle.properties
其他的系统变量这里就不列举了,具体看我们遇到具体场景来设置
接着来看下在gradle.properties文件中如何定义变量,gradle.properties就是官方定义的用来定义变量的文件的地方,所以定义和获取就不需要像local.properties那么麻烦了。
获取变量,就不需要通过文件流读取文件流,gralde内部自身已经做了这个,我们可以直接引用变量即可。
setting.gradle前面的博客介绍了,是用于配置项目的组成和模块的,所以一半我们的setting.gradle文件都是这样的
前面有讲过setting.gradle的实质是生成一个Setting对象,我们按住ctrl点击include就进入了Setting.gradle类,其实就可以知道我们可以调用的api,这里还是介绍我们常用的几个方法吧。首先来看下最常用的 include 方法。
这里特意把注释也放了进来,不得不说老外对于注释真的写的非常详细,往往我们忽视了这么冗长的注释,但当发现问题,从搜索引擎上搜相关资料都时候就会发现,其实大部分就是对于注释都翻译。
所以这里我下面介绍都内容,就会发现和上面注释都大同小异。
首次看下这里的引入方式,一般都是 include ':app' ,这里的语法是这样的
在这里 : 表示的路径的分隔符,也就是 \ 的意思,所以这里都需要使用 : ,其次这里都路径是相当于根目录的路径。然后我们可以看到其实这个方法是可变参数,所以这里支持多个项目引入。
所以我们如果有一个这样的目录结构的项目
那么这时的setting.gradle就是这样
这时我们可能有个问题:我们如果引入的不是根目录下的项目怎么办?也就是引入其他路径下的项目作为我们的子module,因为这里一直是相对与根目录的路径
这样我们就可以引入不在这个项目中的Lib作为我们这个项目的Lib,组件化的工程经常就会这样使用。
最后我们看下还有一个小知识点,我们如果想改变这个Lib在Studio的显示的名称,该如何操作?
这个方法的作用就是我们这样的,可以改变Lib在IDE中的名称。
接着来看下在setting.gradle怎么定义全局变量呢?这时候就是利用gradle的拓展属性的特性了。
然后在build.gradle中使用变量的时候,就还是使用gradle.ext使用即可。
关于ext属性我们后面专门再讲下,我们前面也讲到了我们全局就只会有一个gradle对象,所以这里可以理解是一个全局的map对象,这样就好理解了很多。
至此,本篇博客对于 gradle.properties 、 local.properties 、 setting.gradle 都配置都有了一个较为详细都讲解,我们后面在使用过程中,对于这三个文件的配置都不会那么陌生,并且对于三个文件的差异都有了一个基本都认知,知道我们在定义本地变量,不同人都环境有差异都地方都应该在local.properties配置,大家共同的配置和变量定义可以放到gradle.properties这个专职用于存放配置的文件,最后就是专门用于配置我们项目的目录结构的setting.gradle,当然这个文件也可以用于配置一些变量,这时候我们就要把我单一职责的原则,也就是高内聚,低耦合那一套,按照文件职责进行划分,下一篇博客准备对build.gradle的配置进行讲解。
gradle 配置 nexus repository
1.mac :
1).解压文件进入bin/
2). ./nexus start 可以直接运行,注意有个点
2.windows
1).进入nexus目录,在bin/jsw 下找到nexus.exe
2).nexus.exe / install安装成系统服务
3).nexus.exe / start直接运行
4).nexus.exe / stop停止
尺竖5).nexus.exe / uninstall卸载
3.ubuntu
1).浏览器中 默认网址可以进入管理界面
2).内置账户 admin admin123
3)点击左上螺丝,进入 设置界面,默认内置了一些库
4).点击陵宽大 create repository
普及一下这几种类型的区别:
5).配置仓库
名称可以修改,其他的配置巧庆没有具体了解
6)点击create repository之后就创建成功了,会自动跳转到repository列表界面,点击条目的copy按钮,就可以获取仓库路径了
不详细说明 maven_push.gradle
apply plugin:'maven'
apply plugin:'signing'
configurations {
deployerJars
}
repositories {
mavenCentral()
}
// 判断版本是Release or Snapshots
def isRelease() {
return!VERSION.contains("SNAPSHOT");
}
// 获取仓库url
def getRepositoryUrl() {
returnisRelease() ? RELEASE_URL : SNAPSHOT_URL;
}
uploadArchives {
repositories {
mavenDeployer {
beforeDeployment {
MavenDeployment deployment - signing.signPom(deployment)
}
pom.version = VERSION
pom.artifactId = ARTIFACT_ID
pom.groupId = GROUP_ID
repository(url: getRepositoryUrl()) {
authentication(userName: NAME,password: PASSWORD)// maven授权信息
}
}
}
}
// 进行数字签名
signing {
// 当 发布版本 存在"uploadArchives"任务时,才执行
required { isRelease() gradle.taskGraph.hasTask("uploadArchives") }
sign configurations.archives
}
在build.gradle 中引用maven_push.gradle
gradle.properties中配置账号与仓库链接
最后在task中,点击uploadArchives上传
项目的gradle中配置内部maven库路径
Gradle之全局配置
Gradle全局配置余码流程
3.在主项目根目录的build.gradle中申明一下(声明在好镇 project/buile.gradle 下):
4在项目友毁粗中( app/build.gradle )引用我们的路径配置(如图:)
Mac安装Gradle及配置
gradle官举掘知网
1.安装成功后测试版本
看到这样说明安装成功
2.接下来正消环境变量的配置
2.1找到如图opt/gradle@6(因为我之前有过所以不是opt/gradle),这个目录等会配置环境变散兆量的时候要用到.
2.2在终端打开,输入下面的命令
添加如下信息,对应自己的版本号!
后输入:wq 进行保存退出
输入如下命令,配置生效
测试输入如下命令,查看版本号
4.说明成功
[img]gradle代理设置
Gradle 默认直连网络,即使 Mac 设置了全局代理也是一样。就算你给 Android Studio 设置了代理,它依旧会风轻云淡地直连那个你在中国一辈子也不可能连上的网站……
根据需要在下列所述文件中添加相应配置语句
1、单项目gradle使用代理唯派:gradle/wrapper/gradle-wrapper.properties
2、全局gradle使用代理:userdir/.gradle/gradle.properties
#代理服务器IP/域名
systemProp.http.proxyHost=127.0.0.1
#代理服务器端口
systemProp.http.proxyPort=8080
#代理服务器蠢让需要验证时,填写用户名
systemProp.http.proxyUser=userid
#代理服务器需要验证时,填写密码
systemProp.http.proxyPassword=password
#不需要代理的域名/IP
systemProp.http.nonProxyHosts=*.nonproxyrepos.com|localhost
systemProp.https.proxyHost=127.0.0.1
systemProp.https.proxyPort=8080
systemProp.https.proxyUser=userid
systemProp.https.proxyPassword=password
systemProp.https.nonProxyHosts=*.nonproxyrepos.com|localhost
然后重带山局启部署,Gradle 就会老老实实地走代理部署了。
Linux下Nexus 3私服配置及gradle配置使用
参考战斗名族大神的文章
注:我这里用的是zsh,配置使用 .zshrc
Nexus安装
使用 ./nexus start 启动,如果看到如下界面念毕,证明我们配置成功了
我们现在想增加我们自己的私有仓库,如下图操作就可以
点击 Create repository 选择 maven2 (hosted) 托管模式
到这里我们的私有maven库就配置完成了!!!
我们使用两种方式配置(1:maven方式 ,2:maven-publish方式)
首先我们创建一个测试项目,并创建一个libaray
在我们项颂高中目的根目录的 build.gradle 中配置刚刚建立的仓库
然后在gradle.properties文件中配置我们的gradle(此处配置信息放在local.properties文件中更好,因为该文件是本地文件,不上传至gitlab上)
再次配置我们libraray下 build.gradle 文件
接下来 Sync Now 一下,如果没出错的话证明我们的配置是成功的,接下来我们按照下图点击上传即可
然后回到Nexus界面,如出现下图中的配置,证明我们上传成功了,如下图:
我们单独配置一个名称为 publisher.gradle 文件,如下野山:
在我们使用的地方引入就可以
我们使用命令上传或图形化上传
1:命令
2:图形化
参考:
关于gradle配置和gradle配置maven仓库的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。