zoukankan      html  css  js  c++  java
  • 【Gradle】maven-publish插件的使用

    一、maven-publish介绍

      在 Gradle 1.3 中,引入了一种新的发布机制。这种新机制引入了一些新概念和功能,这些功能使 Gradle 发布变得更加强大,现在已成为发布工件的首选选项。

    二、maven-publish使用

    1、在 build.gradle 声明插件

    plugins {
        id 'maven-publish'
    }

    2、使用publishing{}块进行配置

    group = 'org.example'
    version = '1.0'
    
    publishing {
        publications {
            myLibrary(MavenPublication) {
                from components.java
            }
        }
    
        repositories {
            mavenLocal()
        }
    }

      上面我们定义了一个名为myLibrary的publication,from components.java这句表明是一个java库,也就是最终会以jar包的形式发布。还定义了一个本地maven仓库,表明myLibrary的jar包最终会被发布到本地maven仓库。components定义了发布的组件,支持三个值:components.java(由JavaPlugin添加)、components.web(由WarPlugin添加)、components.javaPlatform(由JavaPlatformPlugin添加)。如果我们需要将一个web项目打包成war包发布,则使用components.web。我们当前的例子为jar,则使用components.java。

      Gradle使用与Maven相同的逻辑来标识本地Maven缓存的位置。如果在settings.xml中定义了本地Maven仓库位置,那么Gradle将使用这个位置。USER_HOME/.m2下的settings.xml将会覆盖M2_HOME/conf中的settings.xml。如果没有可获取的settings.xml,Gradle将默认使用USER_HOME/.m2/repository作为本地Maven仓库位置。

    3、maven-publish提供的tasks

      maven-publish提供了如下tasks:

    任务 描述
    generatePomFileForPubNamePublication 创建需要发布的名为PubName的POM文件,填充已知的元数据,如项目名称、项目版本和依赖项。POM文件的默认位置是build/publications/$pubName/pom-default.xml.
    publishPubNamePublicationToRepoNameRepository 将PubName发布到名为RepoName的存储库。如果你有一个没有显式名称的存储库定义,RepoName将是“Maven”。
    publishPubNamePublicationToMavenLocal 将PubName发布复制到本地Maven缓存-通常是$USER_HOME/.m2/repository-以及发布的POM文件和其他元数据。
    publish 将所有定义的publication发布到所有定义的存储库的聚合任务。它不包括将publication复制到本地Maven库。
    publishToMavenLocal 将所有定义的publication复制到本地 Maven 库中,包括它们的元数据 (POM 文件等)

      

    4、执行任务

    • 命令:gradle tasks

      可以查看所有任务

      

    • 命令:gradle publishToMavenLocal

      执行publishToMavenLocal任务,或者在idea的gradle窗口点击任务名也可以

      查看本地maven仓库,即可发找到发布的jar包

    三、发布class.jar和sources.jar及javadoc.jar 三种jar包

      新建打包sourcesJar任务 和 打包javadocJar任务,然后进行发布,

      新增的 sourcesJar任务 和 javadocJar任务 可以在idea的gradle窗口中other任务列表中看到

      完整代码如下:

     1 // 声明插件
     2 plugins {
     3     id 'maven-publish'
     4 }
     5 
     6 
     7 // 项目group/artifact/version信息
     8 group 'com.test.gradle'
     9 // name 默认项目名
    10 version '1.0-SNAPSHOT'
    11 
    12 
    13 // 打包sourcesJar任务
    14 task sourcesJar(type: Jar, dependsOn: classes) {
    15     classifier = 'sources'
    16     from sourceSets.main.allSource
    17 }
    18 
    19 // 打包javadocJar任务
    20 task javadocJar(type: Jar, dependsOn: javadoc) {
    21     classifier = 'javadoc'
    22     from javadoc.destinationDir
    23 }
    24 
    25 // 解决javadoc打包乱码
    26 javadoc {
    27     options {
    28         encoding "UTF-8"
    29         charSet 'UTF-8'
    30         author true
    31         version true
    32         title "文档大标题"
    33     }
    34 }
    35 
    36 
    37 publishing {
    38     // 发布
    39     publications {
    40         mavenJava(MavenPublication) {
    41             //指定group/artifact/version信息
    42             groupId project.group
    43             artifactId project.name
    44             version project.version
    45             // components.java jar包
    46             // components.web war包
    47             from components.java
    48 
    49             // 增加 sourcesJar、javadocJar 任务
    50             artifact sourcesJar
    51             artifact javadocJar
    52         }
    53     }
    54     // 发布仓库
    55     repositories {
    56    
    57            // 本地仓库位于USER_HOME/.m2/repository
    58            // 
    59         mavenLocal()
    60         // 其他maven仓库
    61         maven { url uri('/Users/h__d/Desktop/1') }
    62         // aliyun镜像仓库
    63 //         maven {
    64 //             // 凭证
    65 //             credentials {
    66 //                 username 'username' // 仓库发布用户名
    67 //                 password 'password' // 仓库发布用户密码
    68 //             }
    69 //             // 地址
    70 //             url 'https://maven.aliyun.com/nexus/content/groups/public/'
    71 //         }
    72     }
    73 }

      发布到配置仓库命令:gradle publish

      发布到本地仓库命令:gradle publishToMavenLocal

      进行发布

      

    参考:

      1、https://blog.csdn.net/u013632755/article/details/100111453

      2、https://blog.csdn.net/dnc8371/article/details/106812825

      3、https://blog.csdn.net/u011578734/article/details/114104495

  • 相关阅读:
    存储过程和函数
    linux命令行执行db2存储过程
    使用 springmvc请求 返回 字符串时 ,中文出现乱码
    shiro + struts2 在action 中使用 shiro 注解 @requiresPermissions 报错: 方法找不到,类初始失败
    spring 注解 注入属性 和 注解完成bean定义
    hibernate4 , spring3 使用 org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean 报错 Implementing class
    action spring 注入错误,如果检查各项注入都没有错误时,考虑struts 是否配置了namespace(如果你有多个namespace="/")
    urlrewritefilter 本地windowsxp 上正常 使用 ,但是 到linux服务器 上 则时好时坏 ,不起作用
    filter 死循环(tomcat 启动完成 ,自动执行filter.dofilter,导致tomcat 启动超时) , tomcat 启动和 servers 启动 不同
    项目 solrcloud / zookeeper 搭建
  • 原文地址:https://www.cnblogs.com/h--d/p/14768794.html
Copyright © 2011-2022 走看看