詳細了解ideaartifacts

一、創建artifact

Ideaartifacts是一個Idea項目的模塊,並且在任何時候都可以被轉換成jar或war文件,然後就可以部署到其他機器上了。創建artifact可以有多種方式,比如右擊項目選擇”Open Module Settings”,然後選擇”Artifacts”選項卡,在這裡可以新增、編輯和刪除artifact。在編輯artifact時候可以選擇output路徑以及包含哪些目錄、文件或者library。另外可以添加directory、jar或者webarchive。

<build>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-jar-plugin</artifactId>
            <version>3.0.2</version>
            <configuration>
                <archive>
                    <index>true</index>
                    <manifest>
                        <addClasspath>true</addClasspath>
                        <mainClass>com.example.Main</mainClass>
                    </manifest>
                    <manifestEntries>
                        <key>Extra-Value</key>
                        <value>Extra-Value-Added</value>
                    </manifestEntries>
                </archive>
            </configuration>
        </plugin>
    </plugins>
</build>

二、編輯artifact

編輯artifact方式多種多樣,比如可以右擊項目選擇”Open Module Settings”,然後選擇”Artifacts”選項卡,找到對應的artifact進行編輯,還可以在項目結構中找到META-INF/Intellij IDEA Artifacts/xxx.xml進行編輯。在編輯artifact時候可以指定文件輸出路徑,還可以對指定的文件進行”Include”或者”Exclude”。一般來說,在”Output Layout”中可以看到自動生成的artifact路徑以及文件,也可以手動添加或者修改需要的文件、library等。

<build>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-assembly-plugin</artifactId>
            <version>3.1.0</version>
            <configuration>
                <appendAssemblyId>false</appendAssemblyId>
                <descriptorRefs>
                    <descriptorRef>jar-with-dependencies</descriptorRef>
                </descriptorRefs>
            </configuration>
        </plugin>
    </plugins>
</build>

三、定義artifact

定義artifact有以下幾種方式:

  • 通過IDEA圖形界面
  • 通過maven配置文件
  • 通過gradle配置文件

1、通過IDEA圖形界面:
在菜單欄中選擇”File”->”Project Structure”,然後選擇”Facets”選項卡,選擇You Web項目,點擊”Add”,在”Add Library”中可以選擇需要的庫文件,選擇完畢後可以在”Artifacts”選項卡中看到我們選擇的jar文件,此時再次選擇”Add”,選擇”From Module Dependency”,這就完成了artifact的定義。

2、通過maven配置文件:
在pom.xml中增加artifacts相關配置,使用maven-assembly-plugin和maven-jar-plugin插件即可完成artifact定義和構建。下面是一個例子,會將主要代碼和依賴打包到一個jar文件中。

<build>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-assembly-plugin</artifactId>
            <version>2.5.5</version>
            <executions>
                <execution>
                    <id>assembly</id>
                    <phase>package</phase>
                    <goals>
                        <goal>single</goal>
                    </goals>
                    <configuration>
                        <finalName>artifactName</finalName>
                        <appendAssemblyId>false</appendAssemblyId>
                        <descriptorRefs>
                            <descriptorRef>jar-with-dependencies</descriptorRef>
                        </descriptorRefs>
                        <archive>
                            <manifest>
                                <mainClass>com.example.Main</mainClass>
                            </manifest>
                        </archive>
                    </configuration>
                </execution>
            </executions>
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-jar-plugin</artifactId>
            <version>2.5</version>
            <configuration>
                <archive>
                    <index>true</index>
                    <manifest>
                        <mainClass>com.example.Main</mainClass>
                    </manifest>
                </archive>
            </configuration>
        </plugin>
    </plugins>
</build>

3、通過gradle配置文件:
在build.gradle中增加artifacts相關配置,使用gradle-assembly-plugin和gradle-jar-plugin插件即可完成artifact的定義和構建。

plugins {
    <code>java
    id 'com.github.johnrengelman.shadow' version '2.0.4'
    
    //以下配置為部署到tomcat需要的插件,如果沒有可以不加
    id 'war'
    id 'org.akhikhl.gretty' version '2.0.0'
}
shadowJar {
    baseName = 'myapi'
    classifier = null
    version = null

    manifest {
        attributes 'Main-Class': 'com.example.Main',
        'Class-Path': configurations.runtime.files.collect { '/usr/lib/' + it.getName() }.join(' ')
    }

    dependencies {
        //thin-jar可以過濾掉一些不需要的依賴,默認會把所有依賴都打包到一個jar中
        //現在只是單純的添加示例,因此下面這段代碼是不完整的,不能直接套用
        compile('com.github.saiprasadkrishnamurthy:thin-jar:1.1') {
            exclude group: 'org.slf4j', module: 'slf4j-log4j12'
        }
    }

    relocate ('com.google.common', 'org.shadow.evermind.com.google.common') {
        exclude 'META-INF/**'
    }
}

四、使用artifact

通過以上步驟已經完成artifact的構建或者定義,下面我們需要學習如何使用artifact。使用artifact有以下幾種方式:

  • 在Idea項目的模塊中使用
  • 在maven項目中使用
  • 在gradle項目中使用

1、在Idea項目的模塊中使用:
選擇”File”->”Project Structure”,然後選擇”Libraries”選項卡,在這裡選擇”New Project Library”並且選擇”Java”,這樣我們就可以添加一個新的library添加artifact了。

2、在maven項目中使用:
在pom.xml中加入以下配置:

<dependencies>
    <dependency>
        <groupId>groupId</groupId>
        <artifactId>artifactId</artifactId>
        <version>version</version>
        <scope>provided</scope>
        <type>war</type>
    </dependency>
</dependencies>

3、在gradle項目中使用:
在build.gradle中加入以下配置:


repositories {
    flatDir { dirs '/path/to/lib/dir' }
}

// 方式2,在gradle中使用mavenCentral()
dependencies {
    implementation 'groupId:artifactId:version'
}

五、其他相關操作

1、創建src/main下的目錄
在menu中選擇”File”->”New”->”Directory”,然後在彈出框的右側選項卡中選擇”Mark Directory as”->”Sources Root”,這樣我們就可以在新建的目錄下放入java源文件了。

2、在main函數中引用resource資源文件
在main函數中加載resource資源文件時候,需要使用以下方法:

public static void main(String[] args) {
    String s = Main.class.getClassLoader().getResource("file.txt").getFile();
    System.out.println(s);
}

3、忽略不必要的warning
在文件名上增加以下注解即可:

@SuppressWarnings("all")
public class MyClass {
    //...
}

4、項目切換成maven的方式
在menu中選擇”File”->”New”->”Project”,然後選擇”Java”->”Maven”,在彈出框中配置相關參數即可。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/308315.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2025-01-03 14:48
下一篇 2025-01-03 14:48

相關推薦

  • index.html怎麼打開 – 詳細解析

    一、index.html怎麼打開看 1、如果你已經擁有了index.html文件,那麼你可以直接使用任何一個現代瀏覽器打開index.html文件,比如Google Chrome、…

    編程 2025-04-25
  • Resetful API的詳細闡述

    一、Resetful API簡介 Resetful(REpresentational State Transfer)是一種基於HTTP協議的Web API設計風格,它是一種輕量級的…

    編程 2025-04-25
  • AXI DMA的詳細闡述

    一、AXI DMA概述 AXI DMA是指Advanced eXtensible Interface Direct Memory Access,是Xilinx公司提供的基於AMBA…

    編程 2025-04-25
  • 關鍵路徑的詳細闡述

    關鍵路徑是項目管理中非常重要的一個概念,它通常指的是項目中最長的一條路徑,它決定了整個項目的完成時間。在這篇文章中,我們將從多個方面對關鍵路徑做詳細的闡述。 一、概念 關鍵路徑是指…

    編程 2025-04-25
  • neo4j菜鳥教程詳細闡述

    一、neo4j介紹 neo4j是一種圖形數據庫,以實現高效的圖操作為設計目標。neo4j使用圖形模型來存儲數據,數據的表述方式類似於實際世界中的網絡。neo4j具有高效的讀和寫操作…

    編程 2025-04-25
  • c++ explicit的詳細闡述

    一、explicit的作用 在C++中,explicit關鍵字可以在構造函數聲明前加上,防止編譯器進行自動類型轉換,強制要求調用者必須強制類型轉換才能調用該函數,避免了將一個參數類…

    編程 2025-04-25
  • HTMLButton屬性及其詳細闡述

    一、button屬性介紹 button屬性是HTML5新增的屬性,表示指定文本框擁有可供點擊的按鈕。該屬性包括以下幾個取值: 按鈕文本 提交 重置 其中,type屬性表示按鈕類型,…

    編程 2025-04-25
  • Vim使用教程詳細指南

    一、Vim使用教程 Vim是一個高度可定製的文本編輯器,可以在Linux,Mac和Windows等不同的平台上運行。它具有快速移動,複製,粘貼,查找和替換等強大功能,尤其在面對大型…

    編程 2025-04-25
  • crontab測試的詳細闡述

    一、crontab的概念 1、crontab是什麼:crontab是linux操作系統中實現定時任務的程序,它能夠定時執行與系統預設時間相符的指定任務。 2、crontab的使用場…

    編程 2025-04-25
  • 網站測試工具的詳細闡述

    一、測試工具的概述 在軟件開發的過程中,測試工具是一個非常重要的環節。測試工具可以快速、有效地檢測軟件中的缺陷,提高軟件的質量和穩定性。與此同時,測試工具還可以提高軟件開發的效率,…

    編程 2025-04-25

發表回復

登錄後才能評論