Gradle 进阶学习之 Gradle插件

1、使用插件的原因

使用插件是现代自动化构建工具中一个非常重要的概念,Gradle 作为其中一个流行工具,通过插件提供了多种便利。以下是使用插件的几个主要原因:

  1. 促进代码重用

    • 减少重复代码:插件允许你重用在不同项目中执行相同功能的代码,减少了编写和维护相似代码的需要。

    • 标准化流程:插件通常封装了一组标准化的操作,使得在多个项目间实现构建流程的一致性变得更加容易。

  2. 提升工作效率

    • 快速实现功能:插件通常提供了一组预定义的任务,可以快速实现打包、测试、部署等功能,从而加速开发流程。

    • 简化构建配置:通过应用插件,可以避免编写复杂的构建脚本,因为插件已经提供了所需的配置。

  3. 项目模块化

    • 解耦功能:插件使得特定的构建功能模块化,这样可以更容易管理和更新这些功能,而不会影响到项目的核心构建脚本。

    • 清晰的构建逻辑:模块化还有助于保持构建逻辑的清晰,使得构建脚本更易于理解和维护。

  4. 自动化和便捷化

    • 自动化流程:插件可以自动化许多繁琐的构建任务,让开发者专注于更重要的业务逻辑。

    • 用户友好:许多插件提供了便捷的命令和配置选项,使得构建过程更加用户友好。

  5. 扩展项目功能

    • 即插即用:插件的可插拔特性意味着你可以轻松地为项目添加新的功能,而无需深入了解实现细节。

    • 社区支持:Gradle 拥有一个活跃的社区,提供了大量的插件,可以扩展构建系统的功能,满足特定的构建需求。

  6. 维护和更新

    • 持续集成:许多插件支持持续集成(CI)流程,可以与 Jenkins、Travis CI 等工具集成,自动化测试和构建流程。

    • 易于更新:插件的更新通常比核心构建系统更容易,因为它们是独立的组件。

2、插件的作用

插件在 Gradle 构建系统中扮演着至关重要的角色,它们为项目提供了额外的功能和自动化能力。以下是插件在项目构建过程中可以完成的一些事情:

  1. 添加任务(Task)

    • 自定义任务:插件可以向项目中添加新的任务,这些任务可以是执行测试、编译源代码、打包应用程序等。

    • 任务配置:插件还可以预配置某些任务,使得开发者不需要手动设置所有参数。

  2. 添加依赖配置

    • 管理依赖:插件可以帮助定义项目的依赖管理,包括外部库依赖、项目内部模块依赖等。

    • 远程仓库:插件可以配置远程仓库,如 Maven Central 或 JCenter,以便下载所需的库。

  3. 扩展项目属性和方法

    • 扩展属性:插件可以向项目添加新的属性,这些属性可以用于控制构建过程或存储配置信息。

    • 扩展方法:插件可以向项目添加新的方法,这些方法可以用于执行特定的构建逻辑或封装复杂的操作。

  4. 项目约定

    • 目录结构:应用特定的插件,如 Java 插件,会为项目设置一些默认的目录结构约定,例如 src/main/java 作为源代码目录。

    • 构建生命周期:插件还可以定义构建过程中的特定阶段,例如编译、测试、打包和部署。

插件是 Gradle 强大的扩展机制,它们可以极大地简化构建配置,提供最佳实践,并允许开发者通过标准化的方式来构建项目。通过应用插件,你可以快速获得构建、测试、打包和依赖管理等自动化功能,同时保持项目的灵活性和可维护性。

3、插件的分类和使用

image-20240420202646427

3.1 脚本插件

在 Gradle 中,脚本插件是一种允许你通过外部 Groovy 脚本文件来扩展构建逻辑的方法。这些脚本可以定义变量、任务、配置等,并且可以通过 apply from 语句被导入到主构建脚本中。

3.1.1 脚本插件的创建

  1. 创建外部脚本文件:你可以创建一个包含 Groovy 代码的文件,比如 version.gradle
// version.gradle
ext {
    company = "阿杰"
    cfgs = [
            compileSdkVersion: JavaVersion.VERSION_21
    ]
    spring = [
            version: '6.0.0'
    ]
}

在这个脚本中,我们使用了 ext 来定义了一系列的属性,这些属性在导入脚本后可以在构建脚本中使用。

3.1.2 脚本插件的应用

  1. 在构建脚本中应用脚本插件:在你的 build.gradle 文件中,使用 apply from 来加载外部脚本。
// build.gradle
apply from: 'version.gradle'

task taskVersion {
    doLast {
        println "博主的昵称:${company}, JDK版本是${cfgs.compileSdkVersion}, 版本号是${spring.version}"
    }
}

在这个构建脚本中,我们应用了之前创建的 version.gradle 脚本。然后我们定义了一个名为 taskVersion 的任务,它会在执行时打印出从脚本插件中导入的变量。

  1. 运行构建:在命令行中运行 Gradle 构建,执行 taskVersion 任务。
gradle taskVersion

image-20240420203619061

执行上述命令后,Gradle 会加载并执行 build.gradle 文件中的指令,包括应用外部脚本插件和执行 taskVersion 任务。

3.1.3 注意事项

  • 脚本位置:确保外部脚本文件的位置是正确的,并且 Gradle 能够找到它。
  • 安全性:从网络上加载脚本时要注意安全性,确保脚本来源可靠,避免执行恶意代码。

总结

脚本插件是 Gradle 提供的一种灵活的扩展机制,允许你通过外部 Groovy 脚本来添加构建逻辑。这种方式非常适合于在多个项目之间共享配置或创建自定义的构建行为。通过使用脚本插件,可按功能把我们的脚本进行拆分一个个公用、职责分明的文件,然后在主脚本文件引用,

比如:将很多共有的库版本号一起管理、应用构建版本一起管理等。可以使构建脚本更加模块化和可重用。

3.2 对象插件

Gradle 的对象插件,也称为二进制插件或 Java 插件,是通过实现 org.gradle.api.Plugin 接口的 Java 类来提供的。这些插件为项目提供了特定的构建功能,并且可以通过一个唯一的插件 ID 来应用到项目中。

image-20240420204109332

3.2.1 内部插件[核心插件]

Gradle 提供了一系列的核心插件,这些插件覆盖了多种常见的构建需求,包括但不限于:

  • Java:支持构建任何类型的 Java 项目。
  • C++ Application:支持在 Windows、Linux 和 macOS 上构建 C++ 应用程序。
  • Application:支持构建基于 JVM 的可运行应用程序。
  • WAR:支持构建和打包基于 WAR 的 Java Web 应用程序。
  • Checkstyle:使用 Checkstyle 对项目中的 Java 源文件执行质量检查。
  • Eclipse:为构建生成 Eclipse 项目文件。
  • IntelliJ IDEA:为构建生成 IDEA 项目文件。

查找核心插件:

要查找 Gradle 提供的所有核心插件,可以访问官方文档中的插件参考页面:

  • Gradle 官方插件参考

在这里,你可以找到每个插件的描述、提供的配置和如何应用该插件的指导。

使用 Java 插件

以下是几种应用 Java 插件到项目中的方法:

  1. 使用插件 ID

    apply plugin: 'java'
    

    这是应用 Java 插件的推荐方式,简洁且易于理解。

  2. 使用闭包

    apply {
        plugin 'java'
    }
    

    这种方式使用了一个闭包来包裹插件 ID,这在需要应用多个插件时非常有用。

  3. 使用全类名

    apply plugin: org.gradle.api.plugins.JavaPlugin
    

    这种方式直接指定了插件的完整类名,这在 IDE 中自动完成代码时可能会看到。

  4. 使用导入的类

    apply plugin: JavaPlugin
    

    如果 org.gradle.api.plugins 包已经被导入,你可以直接使用类名来引用插件。

插件 ID 的唯一性:

每个插件都有一个唯一的插件 ID,这有助于避免名称冲突。通常,插件 ID 会采用应用包名来确保其唯一性,如 java 对应的完整类名为 org.gradle.api.plugins.JavaPlugin

3.2.2 第三方插件

在使用第三方发布的二进制插件时,通常需要确保 Gradle 能够从正确的仓库中获取这些插件。以下是两种常见的方法来应用这些插件:

1. 传统应用方式

使用 buildscript 块,你需要指定插件的类路径和仓库:

buildscript {
    ext {
        springBootVersion = "2.3.3.RELEASE"
    }
    repositories {
        mavenLocal()
        maven { url 'http://maven.aliyun.com/nexus/content/groups/public' }
        jcenter()
    }
    dependencies {
        classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
    }
}

apply plugin: 'org.springframework.boot'

在这个例子中,我们首先定义了 buildscript 块,它告诉 Gradle 从哪里查找插件。repositories 块可以包含多个仓库,这里包括了 Maven 本地仓库、阿里云的 Maven 仓库和 JCenter。

2. plugins DSL 方式

Gradle 引入了一种新的 plugins 块,它提供了一种更简洁的方式来应用插件,特别是当插件被托管在 Gradle 插件仓库 时:

plugins {
    id 'org.springframework.boot' version '2.4.1'
}

使用 plugins 块时,Gradle 会自动从 Gradle 插件仓库中解析插件的坐标,因此你不需要显式地指定类路径和仓库。

3. 注意事项
  1. 位置:在使用传统方式时,buildscript 块必须位于 build.gradle 文件的顶部。而 plugins 块则没有这个限制,可以放在文件的任何位置。

  2. 格式plugins 块使用 idversion 来指定插件的 ID 和版本,这使得构建脚本更加清晰和易于管理。

  3. 自动解析:当使用 plugins 块时,Gradle 会自动解析插件的坐标,这意味着你不需要手动添加仓库和类路径。

  4. 兼容性:确保你使用的 Gradle 版本与第三方插件的版本兼容。

总结

使用 plugins 块可以简化插件的应用过程,特别是当你使用托管在 Gradle 插件仓库中的插件时。这种方式使得构建脚本更加简洁,同时减少了配置错误的可能性。然而,在一些情况下,你可能仍然需要使用传统的 buildscript 方法,比如当插件不是托管在 Gradle 插件仓库中,或者你需要自定义插件的类路径和仓库时。

3.2.3 用户自定义插件

在 Gradle 中,用户自定义插件是一种强大的扩展构建功能的方式。自定义插件允许你封装逻辑,创建新的任务,甚至向项目添加自定义的扩展属性和方法。这些插件可以用于单个项目,也可以被设计为可重用和可共享的。

1. 示例
/**
 * GreetingPluginExtension 接口定义了问候插件的扩展属性。
 * 这个接口规定了插件配置中可以使用的两个属性:getMessage 和 getGreeter。
 */
interface GreetingPluginExtension {
    // getMessage 方法:获取问候语。
    Property<String> getMessage()
    // getGreeter 方法:获取发出问候的实体。
    Property<String> getGreeter()
}

/**
 * GreetingPlugin 类实现了 Plugin 接口,为 Gradle 提供了一个问候插件。
 * 这个插件向项目中添加了一个 'hello' 任务,该任务在执行时会打印一条问候语。
 */
class GreetingPlugin implements Plugin<Project> {
    /**
     * apply 方法将插件应用到指定的项目上。
     * @param project 要应用插件的项目实例。
     */
    void apply(Project project) {
        // 创建一个名为 'greeting' 的插件扩展,允许用户自定义问候语和发出问候的实体。
        def extension = project.extensions.create('greeting', GreetingPluginExtension)

        // 创建一个名为 'hello' 的任务,任务执行时会打印配置的问候语。
        project.task('hello') {
            doLast {
                // 打印问候语,使用插件扩展中配置的消息和发出问候的实体。
                println "${extension.message.get()} from ${extension.greeter.get()}"
            }
        }
    }
}

// 应用 GreetingPlugin 插件到当前的 Gradle 项目中。
apply plugin: GreetingPlugin

// 配置插件扩展,设置问候语和发出问候的实体。
greeting.message = 'Hello from plugin'
greeting.greeter = 'Gradle'

image-20240420212341025

2. 用户自定义插件的局限性

虽然用户自定义插件非常灵活,但它们通常局限于定义它们的项目。这意味着,如果你在一个项目中定义了一个自定义插件,它可能不适用于其他项目,除非你将插件逻辑提取到一个独立的类或 JAR 文件中,并在其他项目中包含这个类或 JAR 文件。

3. 共享自定义插件

为了使自定义插件可重用和共享,你可以:

  • 构建独立插件:将插件代码放入一个独立的项目中,构建为 JAR 文件,然后发布到本地仓库或远程仓库。
  • 使用 buildSrc:对于小型或特定于项目的插件,可以将插件代码放置在项目的 buildSrc 目录中。这样,插件可以被当前项目和子项目使用。
总结

自定义插件是 Gradle 插件系统的重要组成部分,它们允许开发者根据自己的需求扩展构建过程。通过创建自定义插件,你可以增加新的构建任务,定义配置选项,甚至提供全新的构建逻辑。自定义插件的开发需要对 Gradle 插件机制有深入的理解,并且需要遵循一定的设计原则以确保插件的可重用性和可维护性。

4、buildSrc 项目

buildSrc 是 Gradle 提供的一个特殊目录,用于存放构建过程中使用的自定义 Groovy 插件和脚本。这个目录被视为一个独立的 Gradle 项目,你可以在这个目录下编写自己的插件和脚本,它们可以在整个构建过程中被重用。

以下是如何使用 buildSrc 目录的步骤:

4.1 创建 buildSrc 模块

。

将 buildSrc 从 included modules 移除,重新构建。

image-20240502100124262

然后只保留 build.gradle 和 src/main 目录,其他全部删掉

image-20240502100230541

4.2 然后修改 Gradle 中的内容

plugins {
    id 'java'
    id 'groovy' // 必须
    id 'maven-publish'
    id 'java-gradle-plugin' // 必须
}

group = 'com.jie'
version = '1.0'

repositories {
    google()
    jcenter()
    mavenCentral() //必须
}

// 项目入口 插件可以使用java groovy kotlin 三种语言进行编写
sourceSets {
    main {
        groovy {
            srcDir 'src/main/groovy'
        }
        java {
            srcDir 'src/main/java'
        }
    }
}

image-20240502101755522

4.3 创建入口目录,在 src/main 下创建代码入口目录

image-20240502101040546

4.4 实现插件代码

package com.jie

import org.gradle.api.Plugin
import org.gradle.api.Project

class Txt implements Plugin<Project> {
    @Override
    void apply(Project project) {
        project.task("testPlugin") {
            doLast {
                println("Hello,Gradle Plugin")
            }
        }
    }
}

4.5 配置插件入口

// 插件入口
gradlePlugin {
    plugins {
        DependenciesPlugin {
            id = 'com.jie.testPlugin'
            implementationClass = 'com.jie.Txt'
        }
    }
}

image-20240502102521585

4.6 在 module 引入我们写的插件

image-20240502102601436

然后执行插件的Task。

image-20240502102704637

这种形式的写法,在我们整个工程的 module 都可以使用,但也只是限制在本工程,其他工程不能使用。

5、编写在单独项目中

有时候我们需要一个插件在多个工程中使用,这时候我们就需要把插件上传 maven 中。

5.1 新建Module

新建一个名称为plugin的Module。

image-20240502103519070

image-20240502103344774

Gradle Plugin可以用java写,也可以用kotlin、groovy,喜欢用什么就可以在main文件下新建对应语言的文件夹接口,比如groovy文件夹。

5.2 新建文件添加依赖

5.2.1 添加依赖

image-20240502104334240

5.2.2 添加类

之前是用的Groovy写,这次用 Java。

image-20240502104420578

5.2.3 添加插件入口

// 插件入口
gradlePlugin {
    plugins {
        DependenciesPlugin {
            id = 'com.jie.plugin.txtPlugin'
            implementationClass = 'com.jie.plugin.Txt'
        }
    }
}

image-20240502111914030

到此,Plugin的基本雏形就有了。

5.3 发布插件

5.3.1 添加依赖

首先,比较常用的仓库是maven,在plugin>build.gradle文件中先依赖一个maven发布的插件maven-publish

image-20240502104703983

5.3.2 添加发布配置

publishing {
    publications {
        myLibrary(MavenPublication) {
            groupId = 'com.jie.plugin' //指定GAV坐标信息
            artifactId = 'txt'
            version = '1.0'

            from components.java    //发布jar包
        }
    }

    repositories {
        maven {
            url "$rootDir/lib/release"
        }

        //发布项目到私服中
//    maven {
//        name = 'myRepo' //name属性可选,表示仓库名称,url必填
//        //发布地址:可以是本地仓库或者maven私服
//        //url = layout.buildDirectory.dir("repo")
//        //url='http://my.org/repo' // // change URLs to point to your repos, e.g. http://my.org/repo // //认证信息:用户名和密码
//        credentials {
//            username = 'joe'
//            password = 'secret'
//        }
//    }
    }
}

image-20240502105217729

5.3.3 执行发布操作

image-20240502110731057

image-20240502111207922

没有出现可能是idea 没有加载出来,刷新一下项目即可。

image-20240502111304684

5.3.4 使用

在settings.gradle文件中配置插件仓库地址

pluginManagement {
    repositories {
        maven {
            url "$rootDir/lib/release"
        }
    }
}

image-20240502111441643

在project>build.gradle文件中添加插件依赖

buildscript {
    dependencies {
        classpath('com.jie.plugin:txt:1.0')
    }
}

image-20240502112020994

再建一个module进行使用。

image-20240502112406958

编译看效果:

image-20240502112520352

在控制台看到自定义插件的输出,说明自定义插件就已经生效了。

最后,至于如何写一个插件,能帮助项目更加自动化或者便捷化,是值得大家未来需要长期思考、关注、努力的点。

6、插件的关注点

6.1 第一点:插件的引用

apply plugin: '插件名' 

6.2 第二点:主要的功能[任务]

当我们在工程中引入插件后,插件会自动的为我们的工程添加一些额外的任务来完成相应的功能。以 Java 插件为例,当

我们加入 java 插件之后,就加入了如下功能:

image-20240502112825658

具体大家可通过 gradle tasks 查看加入某个插件前后的区别。

说明:Gradle 中的任务依赖关系是很重要的,它们之间的依赖关系就形成了构建的基本流程。

6.3 第三点:工程目录结构

一些插件对工程目结构有约定,所以我们一般遵循它的约定结构来创建工程,这也是 Gradle 的“约定优于配置”原则。

例如 java 插件规定的项目源集目录结构如下所示:

image-20240502112922363

如果要使用某个插件就应该按照它约定的目录结构设置,这样能大大提高我们的效率,当然各目录结构也可以自己定义

6.4 第四点:依赖管理

比如前面我们提到的 依赖的类型[依赖管理]部分,不同的插件提供了不同的依赖管理。

6.5 第五点:常用的属性

例如:Java 插件会为工程添加一些常用的属性,我们可以直接在编译脚本中直接使用。

属性名称类型默认值描述
reportsDirNameStringreports生成报告的目录名称
reportsDirFile (只读)buildDir/reportsDirName生成报告的目录
testResultsDirNameStringtest-results生成测试.result.xml文件的目录名称
testResultsDirFile (只读)reportsDir/testReportDirName生成测试报告的目录
libsDirNameStringlibs生成 lib 库的目录名称
libsDirFile (只读)buildDir/libsDirName生成 lib 库的目录
distsDirNameStringdistributions生成发布文件的目录名称
distsDirFile (只读)buildDir/distsDirName生成发布文件目录
docsDirNameStringdocs生成帮助文档的目录名称
docsDirFile (只读)buildDir/docsDirName生成帮助文档的目录
dependencyCacheDirNameStringStringdependency-cache存储缓存资源依赖信息的目录名称
dependencyCacheDirFile (只读)buildDir/dependencyCacheDirName存储缓存资源依赖信息的目录

7 、Java 插件分析

参考官网:https://docs.gradle.org/current/userguide/plugin_reference.html,以 Java 插件为例,讲解需要关注的几点:

7.1 第一点:我们要关注插件使用

plugins {
	id 'java' 
}

7.2 第二点:我们要关注插件的功能

我们可通过官方文档介绍了解某个插件功能或者百度、再或者大家可以通过 gradle tasks 查看加入 java 插件前后的区别。

7.3 第三点:项目布局

一般加入一个插件之后,插件也会提供相应的目录结构,例如:java 插件的目录结构

image-20240502113555425

当然这个默认的目录结构也是可以改动的例如:

sourceSets {
    main {
        java {
            srcDirs = ['src/java']
        }
        resources {
            srcDirs = ['src/resources']
        }
    }
}

也可设置源集的属性等信息。

7.4 第四点:依赖管理:以 java 插件为例,提供了很多依赖管理项

image-20240502113716311

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/588539.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Linux中gcc/g++的使用

文章目录 前言gcc/g 前言 gcc和g即为编译器。其中gcc为c语言的编译器&#xff0c;只能编译c语言&#xff1b;g为c的编译器&#xff0c;既能编译c语言&#xff0c;又能编译c。 在前面的文章中&#xff0c;我们提到代码转换成可执行程序需要经过 预处理&#xff08;进行宏替换)…

ID决策树的构造原理

前言 &#x1f3f7;️&#x1f3f7;️本章开始学习有关决策树的相关知识&#xff0c;决策树是一种树形模型&#xff0c;也是一种常用的分类和回归方法。本章我们首先介绍第一种决策树的构造原理 学习目标 了解决策树算法的基本思想掌握 ID3 决策树的构建原理 1.决策树介绍 …

Spring Cloud Kubernetes 实践 服务注册发现、服务动态配置

一、Spring Cloud Kubernetes 随着云计算和微服务架构的不断发展&#xff0c;k8s 和Spring Cloud成为了当今技术领域的两大热门话题。k8s作为一个开源的容器编排平台&#xff0c;已经在自动化部署、扩展和管理方面取得了巨大的成功&#xff0c;而Spring Cloud则以其丰富的生态…

区间预测 | PSO-RF-KDE的粒子群优化随机森林结合核密度估计多变量回归区间预测(Matlab)

区间预测 | PSO-RF-KDE的粒子群优化随机森林结合核密度估计多变量回归区间预测&#xff08;Matlab&#xff09; 目录 区间预测 | PSO-RF-KDE的粒子群优化随机森林结合核密度估计多变量回归区间预测&#xff08;Matlab&#xff09;效果一览基本介绍程序设计参考资料 效果一览 基…

傲软录屏(ApowerREC)一款简单好用的录屏软件,中文破姐版 v1.6.9.6(240501)

软件介绍 傲软录屏&#xff0c;是由ApowerREC开发的一款高级录屏软件&#xff0c;兼容多个操作系统平台&#xff0c;包括Windows、Mac以及基于安卓和iOS的设备。这款专业工具具备捕捉各类屏幕活动的能力&#xff0c;确保音视频同步&#xff0c;无论用户是进行电脑桌面操作、参…

C++string类使用大全

目录 温馨提示&#xff1a;这篇文章有约两万字 什么是string类&#xff1f; 一. 定义和初始化string对象 1.string的构造函数的形式&#xff1a; 2.拷贝赋值运算符 3.assign函数 二.string对象上的操作 1.读写string对象 2.读取未知数量的string对象 3.使用getline …

软件工程毕业设计选题100例

文章目录 0 简介1 如何选题2 最新软件工程毕设选题3 最后 0 简介 学长搜集分享最新的软件工程业专业毕设选题&#xff0c;难度适中&#xff0c;适合作为毕业设计&#xff0c;大家参考。 学长整理的题目标准&#xff1a; 相对容易工作量达标题目新颖 1 如何选题 最近非常多的…

Mac brew安装Redis之后更新配置文件的方法

安装命令 brew install redis 查看安装位置命令 brew list redis #查看redis安装的位置 % brew list redis /usr/local/Cellar/redis/6.2.5/.bottle/etc/ (2 files) /usr/local/Cellar/redis/6.2.5/bin/redis-benchmark /usr/local/Cellar/redis/6.2.5/bin/redis-check-ao…

高级商务谈判口才培训教程(3篇)

高级商务谈判口才培训教程&#xff08;3篇&#xff09; 高级商务谈判口才培训教程&#xff08;**篇&#xff09;&#xff1a;基础篇 一、前言 在高级商务谈判中&#xff0c;口才不仅是交流的工具&#xff0c;更是策略执行的关键。本教程将从基础出发&#xff0c;带领大家逐步掌…

【PHP】安装指定版本Composer

1、下载指定版本composer.phar文件&#xff1a;https://github.com/composer/composer/releases 2、将下载的文件添加到全局路径&#xff1a; sudo mv composer.phar /usr/local/bin/composer 3、赋予权限&#xff1a; sudo chmod x /usr/local/bin/composer 4、查看compos…

52.HarmonyOS鸿蒙系统 App(ArkTS)配置文件添加多个权限方法

52.HarmonyOS鸿蒙系统 App(ArkTS)配置文件添加多个权限方法 module.json5

前端开发者如何在项目里控制修改组件的样式

1为了让自己快速下班&#xff0c;修改样式应该是占据大部分时间&#xff0c;在很多组件库的项目里&#xff0c;都会提到主题设置。 比如element的scss配置变量&#xff0c;通常有人喜欢直接引入css样式来快速完成任务&#xff0c;然后在全局覆盖这些选择器对应的样式&#xff0…

OpenCV(二)—— 车牌定位

从本篇文章开始我们进入 OpenCV 的 Demo 实战。首先&#xff0c;我们会用接下来的三篇文章介绍车牌识别 Demo。 1、概述 识别图片中的车牌号码需要经过三步&#xff1a; 车牌定位&#xff1a;从整张图片中识别出牌照&#xff0c;主要操作包括对原图进行预处理、把车牌从整图…

信号知识详解

目录 1、信号的产生 2、core 核心转储 3、信号的保存 4、信号的处理 信号是linux系统提供的&#xff0c;让用户或进程给其他进程发送异步信息的一种方式。 常见的信号处理方式&#xff1a; 1、默认行为 2、忽略 3、自定义 1、信号的产生 1、kill命令 我们可以使用命令 k…

过渡与动画

单元素/组件过渡 Vue在插入、更新或者移除 DOM 时&#xff0c;提供多种不同方式的过渡效果&#xff08;一个淡入淡出的效果&#xff09; 在条件渲染&#xff08;使用v-if&#xff09;、条件展示&#xff08;使用v-show&#xff09;、动态组件、组件根节点等情形中&#xff0c;可…

【火猫DOTA2】电竞世界杯DOTA2项目将在7月份的前三周举办

1、电竞世界杯将于今年7月3日至8月25日在沙特利雅得举办。近日主办方公布了各个项目的举办时间,其中DOTA2项目将在7月份的前三周举办。转载:火猫TV资讯https://www.huomaotv.com/ 目前Falcons、XG、GG和Liquid这五支赢得了足够EPT积分的队伍已经确定直邀沙特。剩下的三个名额还…

SpringBoot集成Kafka开发

4.SpringBoot集成Kafka开发 4.1 创建项目 4.2 配置文件 application.yml spring:application:name: spring-boot-01-kafka-basekafka:bootstrap-servers: 192.168.2.118:90924.3 创建生产者 package com.zzc.producer;import jakarta.annotation.Resource; import org.spri…

MATLAB 数据输出

MATLAB 数据输出 数据导出(或输出)在 MATLAB 的意思是写入文件。MATLAB 允许您在另一个读取 ASCII 文件的应用程序中使用您的数据。为此&#xff0c;MATLAB 提供了几个数据导出选项。 您可以创建以下类型的文件- 数组中的矩形、分隔的ASCII数据文件。 击键的日记&#xff08…

Linux系统安装Redis7(详细版)

Linux系统安装Redis7 一、windows安装redis二、Linux安装Redis下载redis编辑redis7.conf文件启动redis-server服务如何关闭redis服务设置Redis开机自启动 一、windows安装redis Window 下安装 下载地址&#xff1a;https://github.com/dmajkic/redis/downloads 下载到的Redi…

6.k8s中的secrets资源

一、Secret secrets资源&#xff0c;类似于configmap资源&#xff0c;只是secrets资源是用来传递重要的信息的&#xff1b; secret资源就是将value的值使用base64编译后传输&#xff0c;当pod引用secret后&#xff0c;k8s会自动将其base64的编码&#xff0c;反编译回正常的字符…