此文章基于Gradle 4.6编写。
使用Maven Plugin发布Artifcat是旧的插件,新版Gradle有新的插件Maven Publish Plugin发布Artifact
官方文档
Maven Plugin
是添加支持发布artifact
到Maven仓库的插件。
需要使用Maven plugin
插件,首先需要在项目的构建脚本build.gradle
上添加插件引用声明:
apply plugin: 'maven'
Maven Plugin
定义了以下任务
任务名称 | 依赖于 | 类型 | 描述 |
---|---|---|---|
install |
构建关联归档的所有任务。 | Upload |
将关联的工件安装到本地Maven缓存,包括Maven元数据生成。默认情况下,安装任务与archives配置相关联。默认情况下,此配置仅将默认jar作为元素。要了解有关安装到本地存储库的更多信息,请参阅:“安装到本地存储库”一节 |
Maven Plugin
没有定义任何依赖配置。
使用Gradle,您可以部署到远程Maven存储库或安装到本地Maven存储库。这包括所有Maven元数据操作,也适用于Maven快照。事实上,Gradle的部署与Maven是100%兼容,因为使用了本机Maven Ant任务。
如果没有POM文件,Gradle可以根据它具有的依赖性信息为您生成一个POM文件。
如果项目只生成默认的jar文件,要将此jar文件部署到远程Maven存储库,在build.gradle
添加以下代码:
apply plugin: 'maven' // 启用Maven Plugin
uploadArchives {
repositories {
mavenDeployer {
repository(url: "file://localhost/tmp/myRepo/") // url的值为存储仓库地址
}
}
}
执行uplaodArchives
任务,Gradle会生成一个POM文件,并将jar文件上传发布到存储仓库中。
如果需要支持除file
以外的协议,还有更多工作要做。在这种情况下,Maven代码需要额外的库。具体需要哪些库取决于所使用的协议。
协议 | 依赖库 |
---|---|
http | org.apache.maven.wagon:wagon-http:2.2 |
ssh | org.apache.maven.wagon:wagon-ssh:2.2 |
ssh-external | org.apache.maven.wagon:wagon-ssh-external:2.2 |
ftp | org.apache.maven.wagon:wagon-ftp:2.2 |
webdav | org.apache.maven.wagon:wagon-webdav:1.0-beta-2 |
file | - |
加入需要使用ssh
协议,需要在build.gradle
这么做:
// 声明一个configuration
configurations {
deployerJars
}
repositories {
mavenCentral()
}
dependencies {
// deployJar是前面configuration声明的
deployerJars "org.apache.maven.wagon:wagon-ssh:2.2" // ssh依赖库
}
uploadArchives {
repositories.mavenDeployer {
configuration = configurations.deployerJars
repository(url: "scp://repos.mycompany.com/releases") {
authentication(userName: "me", password: "myPassword") // 这里是仓库账号认证设置,用户名和密码
}
}
}
Maven发布有许多配置项,这些配置项是依赖Groovy构建器完成的。配置项的所有元素都是Java bean。配置简单的属性,可以直接映射到bean的元素。如果添加bean元素到他的父元素,可以使用闭包。(在上面的例子中,repository
和authentication
就是添加到父元素的bean元素),下标列出了可用的bean】元素及只想相应类的javadoc的链接。
元素 | Javadoc链接(只想Gradle官网) |
---|---|
root | MavenDeployer |
repository | org.apache.maven.artifact.ant.RemoteRepository |
authentication | org.apache.maven.artifact.ant.Authentication |
releases | org.apache.maven.artifact.ant.RepositoryPolicy |
snapshots | org.apache.maven.artifact.ant.RepositoryPolicy |
proxy | org.apache.maven.artifact.ant.Proxy |
snapshotRepository | org.apache.maven.artifact.ant.RemoteRepository |
在Maven中,可以定义存储仓库和可选的快照存储仓库。如果没有定义快照存储仓库,会将版本和快照部署到这个repository
元素配置的存储仓库,如果配置了快照,快照将部署到snapshortRepository
元素配置的存储仓库中。
Maven Plugin
会往项目中添加install
任务。这个任务依赖于所有archives
配置的归档任务。它将安装这些归档文件到本地仓库存储中(如果在Maven在string.xml中重新配置了默认仓库的位置,这个任务将会根据改配置指向新的存储位置)。
当发布构件到Maven仓库时,Gradle会自动生成一个POM文件。POM文件包含groupId
、artifactId
、version
、packaging
、dependency
元素(参考下表),dependency
元素通过项目的依赖定义创建。
Maven元素 | 默认值 | 备注 |
---|---|---|
groupId | project.group | 组id |
artifactId | uploadTask.repositories.mavenDeployer.pom.artifactId (if set) or archiveTask.baseName. | 构件id |
version | project.version | 发布版本 |
packaging | archiveTask.extension | 文件打包后缀,如jar,aar |
在这里,uploadTask
和archiveTask
任务是分别用来上传和生成归档文件的(比如:uploadArchives
和jar
)。archiveTask.basename
默认是archiveTask.archivesBasename
的值,而archiveTask.archivesBasename
的默认值是project.name
的值。
当你设置
arhiveTask.baseName
属性值代替默认值是,还必须设置uploadtask.prepositories.mavenDeployer.pom.artifactId
为相同值,否则,在同一个构建中的不同项目里,可能会在生成POM文件时引用错误artifaceId。
生成的POM文件可以在
目录下找到,他们可以通过MavenPom
API进行自定义。例如,你可以将部署到Maven存储仓库的工件具有与Gradle编译生成的工件有不同的版本或者名称。要做到这些,可以根据以下方法:
uploadArchives {
repositories {
mavenDeployer {
repository(url: "file://localhost/tmp/myRepo/")
pom.version = '1.0Maven' // 发布到仓库的构建版本
pom.artifactId = 'myMavenName' // 发布到仓库的构建id
}
}
}
添加额外的内容到POP文件,可用pom.project
构建器,使用这个而构建起,所有在Maven POM引用中列出的元素都可以添加到里面。
uploadArchives {
repositories {
mavenDeployer {
repository(url: "file://localhost/tmp/myRepo/")
pom.project {
licenses {
license {
name 'The Apache Software License, Version 2.0'
url 'http://www.apache.org/licenses/LICENSE-2.0.txt'
distribution 'repo'
}
}
}
}
}
}
注意:
groupId
,artifactId
,version
和packaging
应始终在pom
对象中进行设置。
Maven插件还支持同时发布多个工件,这时需要为要发布的每个工件声明一个过滤器。此过滤器定义了一个布尔表达式,它接受Gradle工件。每个过滤器都有一个与之关联的POM,您可以配置它。要了解更多相关信息,请查看PomFilterContainer及其相关课程。
通过Java和War插件添加的Gradle配置与Maven作用域之间,Maven插件配置了默认映射。大多数情况下,您可以跳过这部分而不需要关注它。映射的工作原理是:您可以将配置映射到一个且仅一个作用域,可以将不同的配置映射到一个或不同的作用域,您还可以为特定的配置到作用域映射分配优先级。看看Conf2ScopeMappingContainer了解更多。
在AndroidStudio中使用Maven插件发布工件到远程仓库存储,在需要发布的模块下面的build.gradle添加以下配置
apply plugin: maven
uploadArchives {
repositories {
mavenDeployer {
// 仓库地址
repository(url: repositoryUrl) {
// 用户校验 用户名/密码
authentication(userName: uname, password: pwd)
}
// 快照仓库地址(可选)
snapshotRepository(url: repositorySnapshotUrl) {
// 用户校验 用户名/密码
authentication(userName: uname, password: pwd)
}
pom.project {
name artifactName // artifact名称
version versionName // artifact版本
artifactId _artifactId // artifact id
groupId _groupId // artifact所属Group Id
packaging packagingType // 文件格式,例如jar、aar
description _description // 描述
}
}
}
}
配置好后,打开Gradle面板,双击模块名称/Tasks/upload/uploadArchives
任务或者在命令行输入gradle 模块名称:uploadArchives
执行命令发布到远程仓库,如果出现BUILD SUCCESS
字样说明发布成功。
官方文档
Maven Publish Plugin通过项目中以publishing
命名,PublishingExtension类型的扩展来实现。该扩展提供了一个称为publications
的容器和一个称为repositories
的容器,Maven Publish Plugin适用于MavenPublication发布和MavenArtifactRepository仓库。
使用Maven Publish Plugin,需要在构建脚本中添加代码启用以下插件
apply plugin: 'maven-publish'
出版物对象描述创建的出版物的结构/配置,出版物通过任务发布到仓库存储,出版物配置明确发布内容。项目中的出版物都在 PublishingExtension.getPublications()容器中定义。
要使Maven Publish Plugin生效,必须将MavenPublication添加到出版物集合中,此出版物确定发布的工件以及关联的POM文中包含的详细信息。出版物可以通过添加组件、自定义工件以及修改生成的POM文件来配置发布。
发布Gradle项目到Maven仓库最简单的方式,就是通过SoftwareComponent来发布。该组件目前支持的出版物包括:
名称 | 内容提供者 | 工件 | 依赖 |
---|---|---|---|
java | Java Plugin | 生成jar文件 | 依赖来自runtime 配置 |
web | War Plugin | 生成war文件 | 没有依赖 |
说明:因为
java
插件与com.android.library
和com.android.application
不兼容,所以在AndroidStudio中,使用maven-plugin
插件时不可同时使用java
插件。
在AndroidStudio中使用Maven插件发布工件到远程仓库存储,在需要发布的模块下面的build.gradle添加以下配置。
apply plugin: 'maven-publish'
publishing {
repositories {
maven {
credentials {
username 'username' // 仓库发布用户名
password 'password' // 仓库发布用户密码
}
url 'trunk_url' // 仓库地址
}
}
publications {
maven(MavenPublication) {
groupId 'group_id' // groupId
artifactId 'artifact_id' // artifactId
version '1.0.0' // 发布版本
description 'This is a liberary to test v1.0.0' // 说明描述
}
}
}
配置好后,打开Gradle面板,双击模块名称/Tasks/publishing/publishMavenPublicationToMavenRepository
任务或者在命令行输入gradle 模块名称:publishMavenPublicationToMavenRepository
执行命令发布到远程仓库,如果出现BUILD SUCCESS
字样说明发布成功。
Read timeout
网络异常报错信息似以下的例子
Upload http://192.168.33.110:8081/repository/RastarGameSdkOversea/com/test/maven/plugin/rastar-sdk-line/1.0.0/rastar-sdk-line-1.0.0.pom
Could not transfer artifact com.test.maven.plugin:rastar-sdk-line:pom:1.0.0 from/to remote (http://192.168.33.110:8081/repository/RastarGameSdkOversea/): Could not write to resource 'com/test/maven/plugin/rastar-sdk-line/1.0.0/rastar-sdk-line-1.0.0.pom'
:rsdk_line:publishAarPublicationToMavenRepository FAILED
FAILURE: Build failed with an exception.
* What went wrong:
Execution failed for task ':rsdk_line:publishAarPublicationToMavenRepository'.
> Failed to publish publication 'aar' to repository 'maven'
> Could not write to resource 'http://192.168.33.110:8081/repository/RastarGameSdkOversea/com/test/maven/plugin/rastar-sdk-line/1.0.0/rastar-sdk-line-1.0.0.pom'.
> Read timed out
* Try:
Run with --stacktrace option to get the stack trace. Run with --info or --debug option to get more log output. Run with --scan to get full insights.
* Get more help at https://help.gradle.org
BUILD FAILED in 44s
根据报错信息,是设置了代理,检查AnroidStudio是否设置了代理,如果没有,打开Gradle用户目录(一般是在C:\Users\用户名\.gradle
),打开gradle.properties
文件,看看是否设置了代理,如果设置了,将其去掉。
gradle.properties
设置代理的配置如下。systemProp.http.proxyHost=127.0.0.1
systemProp.http.proxyPort=1080
ERROR: Cannot configure the 'publishing' extension after it has been accessed.
配置好后,刷新Gradle的时候,如果出现ERROR: Cannot configure the 'publishing' extension after it has been accessed.
错误,可以将以上的配置修改一下
apply plugin: 'maven-publish'
publishing {
repositories {
maven {
credentials {
username 'username' // 仓库发布用户名
password 'password' // 仓库发布用户密码
}
url 'trunk_url' // 仓库地址
}
}
publications {
maven(MavenPublication) {
groupId 'group_id' // groupId
artifactId 'artifact_id' // artifactId
version '1.0.0' // 发布版本
description 'This is a liberary to test v1.0.0' // 说明描述
}
}
}
将多级闭包改为少一级,将publishing
跟闭包下面的使用.
链接在一起,如下:
apply plugin: 'maven-publish'
publishing.repositories {
maven {
credentials {
username 'username' // 仓库发布用户名
password 'password' // 仓库发布用户密码
}
url 'trunk_url' // 仓库地址
}
}
publishing.publications {
maven(MavenPublication) {
groupId 'group_id' // groupId
artifactId 'artifact_id' // artifactId
version '1.0.0' // 发布版本
description 'This is a liberary to test v1.0.0' // 说明描述
}
}