0

0

在Gradle多模块项目中构建与消费自定义插件的指南

碧海醫心

碧海醫心

发布时间:2025-11-30 20:13:02

|

685人浏览过

|

来源于php中文网

原创

在Gradle多模块项目中构建与消费自定义插件的指南

本文探讨了在gradle多模块项目中构建和消费自定义插件时遇到的“插件未找到”问题及其解决方案。核心在于利用gradle的复合构建(composite builds)功能,通过在根项目的`settings.gradle.kts`中使用`includebuild()`指令,并为插件模块提供独立的`settings.gradle.kts`文件,确保插件在被其他模块消费前得到正确构建和解析。这使得插件能够无缝集成到同一项目结构中,简化了开发工作流。

在大型多模块项目中,为了统一和简化特定模块的构建配置,开发自定义Gradle插件是一种常见且高效的实践。例如,一个库可能需要针对其依赖项目配置特定的测试套件,此时一个自定义插件就能自动化这些配置。然而,当尝试在同一个多模块项目内部构建并消费这个插件时,开发者可能会遇到“插件未找到”的问题。

挑战:在多模块项目中消费内部插件

通常,一个Gradle多模块项目的结构可能如下所示:

+ root
  + my-api/          // 接口模块
  + my-implementation/ // 实现模块,依赖my-api并尝试消费自定义插件
  + my-gradle-plugin/  // 自定义Gradle插件模块
    + build.gradle.kts
  + build.gradle.kts   // 根项目构建脚本
  + settings.gradle.kts // 根项目设置脚本
  + gradle.properties

其中,my-gradle-plugin模块负责定义和实现自定义插件。其build.gradle.kts可能包含如下配置:

// my-gradle-plugin/build.gradle.kts
plugins {
    `java-gradle-plugin`
    `maven-publish`
}

gradlePlugin {
    plugins {
        create("org.my.gradle.plugin") {
            id = "org.my.gradle.plugin"
            group = "org.my.gradle.plugin"
            implementationClass = "org.my.gradle.plugin.MyGradlePlugin"
            version = project.version
        }
    }
}

当my-implementation模块尝试通过plugins { id("org.my.gradle.plugin") version "internal" }来应用这个插件时,Gradle可能会报告以下错误:

* What went wrong:
Plugin [id: 'org.my.gradle.plugin', version: '0.0.3-SNAPSHOT'] was not found in any of the following sources:

- Gradle Core Plugins (plugin is not in 'org.gradle' namespace)
- Plugin Repositories (could not resolve plugin artifact 'org.my.gradle.plugin:org.my.gradle.plugin.gradle.plugin:0.0.3-SNAPSHOT')
  Searched in the following repositories:
    MavenLocal(...)
    maven(...)
    Gradle Central Plugin Repository
    MavenRepo

这个错误表明Gradle在解析my-implementation模块时,无法在配置的插件仓库中找到org.my.gradle.plugin。问题在于,Gradle默认并不知道my-gradle-plugin模块需要先被构建成一个可用的插件,才能在同一个构建过程中被其他模块消费。它会将插件视为外部依赖,尝试从远程或本地Maven仓库中查找。

极品HTML5网络建站公司模板源码(包含源文件)3.0
极品HTML5网络建站公司模板源码(包含源文件)3.0

1、架构轻盈,完全免费与开源采用轻量MVC架构开发,兼顾效率与拓展性。全局高效缓存,打造飞速体验。 2、让简洁与强大并存强大字段自定义功能,完善的后台开关模块,不会编程也能搭建各类网站系统。 3、顶级搜索引擎优化功能纯静态、伪静态,全部支持自由设置规则,内容、栏目自由设置URL格式。 4、会员、留言、投稿、支付购物神马一个不能少不断升级完善的模块与插件,灵活的组装与自定义设置,满足你的多样需求。

下载

解决方案:利用Gradle复合构建(Composite Builds)

解决这个问题的关键在于利用Gradle的复合构建(Composite Builds)功能。复合构建允许将多个独立的Gradle构建(包括插件项目)组合成一个单一的构建。这样,主构建就可以在本地解析和使用“包含”的构建所提供的插件或项目。

具体步骤如下:

  1. 为插件模块创建独立的settings.gradle.kts: 在my-gradle-plugin模块的根目录下创建一个空的settings.gradle.kts文件。这个文件将把my-gradle-plugin标记为一个独立的Gradle构建,使其能够被主项目作为复合构建的一部分来“包含”。即使是空文件,它的存在也是必要的。

    + root
      + my-gradle-plugin/
        + build.gradle.kts
        + settings.gradle.kts // 新增文件
  2. 在根项目的settings.gradle.kts中声明includeBuild(): 在主项目的settings.gradle.kts中,使用includeBuild()指令将my-gradle-plugin模块作为复合构建包含进来。这会告诉Gradle,在构建主项目之前,需要先构建my-gradle-plugin。

    // ./root/settings.gradle.kts
    
    rootProject.name = "root-project"
    
    // 包含其他子模块
    include("my-api", "my-implementation")
    
    // 关键:将插件模块作为复合构建包含进来
    pluginManagement {
        includeBuild("my-gradle-plugin") // 指向插件模块的路径
        repositories {
            mavenLocal()
            maven { url = uri("https://xyz") } // 你的私有仓库
            gradlePluginPortal()
            mavenCentral()
        }
        resolutionStrategy {
            val version: String by settings
            eachPlugin {
                // 确保自定义插件使用根项目定义的版本
                if (requested.id.id == "org.my.gradle.plugin") {
                    useVersion(version)
                }
            }
        }
    }
    • includeBuild("my-gradle-plugin"): 这行代码指示Gradle将my-gradle-plugin目录下的项目视为一个独立的构建,并将其纳入当前构建的范围。Gradle会确保在需要该插件时,它已经被构建并可用。
    • pluginManagement块中的resolutionStrategy: 这是一个最佳实践,确保你的自定义插件能够正确解析到根项目gradle.properties中定义的版本(例如version=0.0.3-SNAPSHOT),而不是尝试从远程仓库查找特定版本。version: String by settings用于从settings.gradle.kts中获取gradle.properties定义的属性。
  3. 消费插件: 完成上述配置后,my-implementation模块就可以像消费任何其他插件一样,直接应用自定义插件了。

    // my-implementation/build.gradle.kts
    plugins {
       id("org.my.gradle.plugin") version "internal" // "internal" 或具体的版本号,取决于resolutionStrategy
    }

    这里使用"internal"作为版本号,是因为pluginManagement中的resolutionStrategy会强制使用根项目定义的版本。如果你的resolutionStrategy配置不同,你可能需要指定实际的版本号。

注意事项

  • Gradle版本兼容性: 上述方法在Gradle 7.5及更高版本中验证有效。对于更早的Gradle版本,行为可能有所不同,建议查阅对应版本的Gradle文档。
  • 插件模块的独立性: 在插件模块内部添加settings.gradle.kts,即使是空文件,也至关重要。它将该模块提升为一个独立的Gradle构建,使得includeBuild()能够识别并管理它。
  • 版本管理: 推荐使用resolutionStrategy来统一管理自定义插件的版本,使其与主项目的版本保持一致,避免因版本不匹配导致的问题。

通过采用复合构建和includeBuild()机制,开发者可以在一个统一的多模块项目中无缝地构建和消费自定义Gradle插件,极大地简化了开发和维护工作流,提升了项目的模块化和可配置性。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Java Maven专题
Java Maven专题

本专题聚焦 Java 主流构建工具 Maven 的学习与应用,系统讲解项目结构、依赖管理、插件使用、生命周期与多模块项目配置。通过企业管理系统、Web 应用与微服务项目实战,帮助学员全面掌握 Maven 在 Java 项目构建与团队协作中的核心技能。

0

2025.09.15

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

421

2023.08.02

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

421

2023.08.02

PHP 命令行脚本与自动化任务开发
PHP 命令行脚本与自动化任务开发

本专题系统讲解 PHP 在命令行环境(CLI)下的开发与应用,内容涵盖 PHP CLI 基础、参数解析、文件与目录操作、日志输出、异常处理,以及与 Linux 定时任务(Cron)的结合使用。通过实战示例,帮助开发者掌握使用 PHP 构建 自动化脚本、批处理工具与后台任务程序 的能力。

40

2025.12.13

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

25

2026.01.26

edge浏览器怎样设置主页 edge浏览器自定义设置教程
edge浏览器怎样设置主页 edge浏览器自定义设置教程

在Edge浏览器中设置主页,请依次点击右上角“...”图标 > 设置 > 开始、主页和新建标签页。在“Microsoft Edge 启动时”选择“打开以下页面”,点击“添加新页面”并输入网址。若要使用主页按钮,需在“外观”设置中开启“显示主页按钮”并设定网址。

6

2026.01.26

苹果官方查询网站 苹果手机正品激活查询入口
苹果官方查询网站 苹果手机正品激活查询入口

苹果官方查询网站主要通过 checkcoverage.apple.com/cn/zh/ 进行,可用于查询序列号(SN)对应的保修状态、激活日期及技术支持服务。此外,查找丢失设备请使用 iCloud.com/find,购买信息与物流可访问 Apple (中国大陆) 订单状态页面。

25

2026.01.26

npd人格什么意思 npd人格有什么特征
npd人格什么意思 npd人格有什么特征

NPD(Narcissistic Personality Disorder)即自恋型人格障碍,是一种心理健康问题,特点是极度夸大自我重要性、需要过度赞美与关注,同时极度缺乏共情能力,背后常掩藏着低自尊和不安全感,影响人际关系、工作和生活,通常在青少年时期开始显现,需由专业人士诊断。

3

2026.01.26

windows安全中心怎么关闭 windows安全中心怎么执行操作
windows安全中心怎么关闭 windows安全中心怎么执行操作

关闭Windows安全中心(Windows Defender)可通过系统设置暂时关闭,或使用组策略/注册表永久关闭。最简单的方法是:进入设置 > 隐私和安全性 > Windows安全中心 > 病毒和威胁防护 > 管理设置,将实时保护等选项关闭。

5

2026.01.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.9万人学习

C# 教程
C# 教程

共94课时 | 7.7万人学习

Java 教程
Java 教程

共578课时 | 51.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号