Maven
IntelliJ IDEA supports the Maven version 3.1 and later.
The default bundled Maven version is 3.9.8.
IntelliJ IDEA supports a fully-functional integration with Maven that helps you automate your building process. You can easily create a new Maven project, open and sync an existing one, add a Maven support to any existing IntelliJ IDEA project, configure and manage a multi-module project.
You can also create a Maven project and store it in the WSL environment or open it from the WSL file system. For more information, refer to the WSL section.
note
If you want to use a custom Maven version that is not bundled with IntelliJ IDEA, you need to install it locally.
If no project is currently open in IntelliJ IDEA, click New Project on the Welcome screen. Otherwise, select File | New | Project from the main menu.
Name the new project and change its location if necessary.
Select the Create Git repository to place the new project under version control.
You will be able to do it later at any time.
Select a language that you want to use in your project. Click if you want to add other languages available via plugins.
Select Maven in the list of Build system.
Specify project's SDK (JDK) or use the default one.
The selected Add sample code option will create a file with a basic code sample.
In Advanced Settings, specify the following Maven coordinates that are added to the pom.xml file:
GroupId - a package of a new project.
ArtifactId - a name of your project.
For more information about Maven coordinates, refer to Maven naming conventions.
Click Create.
IntelliJ IDEA creates a Maven project with the pom.xml file that includes compiler source and target versions of Java, the dedicated Maven tool window, and all the necessary dependencies to start your work.
note
The version of Java specified in the pom.xml file overrides the version specified in the JDK for Importer option, located in the Maven settings.
Launch the New Project wizard. If no project is currently opened in IntelliJ IDEA, click New Project on the welcome screen. Otherwise, select File | New | Project from the main menu.
Select Maven Archetype from the options on the left.
Using options on the right, configure your project:
Name: specify the name of your project.
Location: specify the location of your project.
Create Git repository:
Select the Create Git repository to place the new project under version control.
You will be able to do it later at any time.
note
The
.gitignore
file is generated in any case.JDK: specify project's SDK (JDK) or use the default one.
Catalog: specify which Maven repository you want to use in your project.
The internal Maven catalog is a default one. You can also select the local repository that is located in the
.m2
directory, or you can select Maven central repository.You can also click Manage Catalogs and add a custom repository if you need.
Archetype: select the needed Maven archetype. Click Add to specify the custom archetype.
Version: the version is specified automatically.
Additional properties: add additional properties
note
If you are creating a project using a Maven archetype, IntelliJ IDEA displays the Maven settings that you can use to set the Maven home path and Maven repositories. Also, you can check the archetype properties.
To modify or add archetype catalogs later in your project, refer to the Archetype Catalogs settings.
Launch the New Project wizard. If no project is currently opened in IntelliJ IDEA, click New Project on the welcome screen. Otherwise, select File | New | Project from the main menu.
Select Jakarta EE from the list of generators.
Leave the default option Maven as your build tool system.
Select additional libraries and frameworks.
Specify your project's name, location, and artifact coordinates. Click Create.
IntelliJ IDEA creates a Maven project with the dedicated Maven tool window and adds necessary dependencies.
For the more detailed information, refer to Tutorial: Your first Jakarta EE application.
Go to File | Open.
Alternatively, click Open on the welcome screen.
note
If you have some custom plugins that require you to import your project from the IntelliJ IDEA model, press CtrlShift0A and search for the Project from Existing Sources action.
In the dialog that opens, select the pom.xml file of the project you want to open.
Click OK.
In the dialog that opens, click Open as Project.
IntelliJ IDEA opens and syncs the Maven project in the IDE. If you need to adjust importing options when you open the project, refer to the Maven settings. For example, if you have Maven options configured in the maven/config
file and want to use them in your project, select the Use settings from .mvn/maven.config option in the Maven setting.
tip
If you have a Maven project with the configured Maven wrapper then IntelliJ IDEA will take the Maven version from the maven.properties file and add it as the Maven home path.
You can configure IntelliJ IDEA to display Maven settings before you open a new Maven project. (A new Maven project in this case is the existing project that you open in IntelliJ IDEA for the first time.) Since these are application-level settings, they are applied to any new project you open.
On the Welcome screen, select Customize | All Settings.
Alternatively, go to File |New Project Setup | Preferences for New Projects in the main menu.
In the Settings dialog, select Build, Execution, Deployment | Build Tools | Maven.
In the Maven settings dialog, select the Show settings dialog for new Maven projects.
Click OK to save the changes.
Next time you open a new project, IntelliJ IDEA displays the Maven Settings dialog where you can specify a location of the local Maven repository and a user settings file.
You can add a Maven module to the project in which you are already working.
In the Project tool window, right-click the project folder and select New | Module. Alternatively, go to File| New | Module in the main menu to open the New Module wizard.
If you used the main menu to add a module, then the process of adding a module is the same as Creating a new Maven project.
If you are adding submodules by right-clicking the root folder then the process of adding a new module is shorter. You need to specify the name of your module in the Name field. The rest of the information is added automatically, and you can use either the default settings or change them according to your preferences.
You can create a multi-module Maven project in IntelliJ IDEA. The multi-module project is defined by a parent POM file with several submodules.
note
If you have the Maven version 3.7 or later installed, IntelliJ IDEA will support importing a project from the MNG-6656 model.
In this case when you open a child POM file in the editor, you don't have to specify a version inside the
parent
tags if it is located in therelativePath
by default. If you add a dependency to a module in the same project, you don't have to specify a version of the dependent module.
Create a Maven parent project. IntelliJ IDEA creates a standard Maven layout including an src folder.
In the Project tool window, remove the src folder since you would only need it in the very rare cases. For your general project, you don't need the src folder for the parent POM.
In the Project tool window, right-click your project (or in the main menu, go to File) and select New | Module to add a subproject.
In the New Module wizard following the instructions on how to add a module, specify the necessary information and click Finish.
The src folder is created automatically, and you can open POM and add a packaging that you need. IntelliJ IDEA adds the module to the parent project. IntelliJ IDEA also adds name and the description of the subproject to the parent POM.
note
In a multi-module project, the parent POM needs to have a
pom
packaging.Last, but not least, IntelliJ IDEA adds the description of the parent POM to the subproject's POM.
You can click in the left gutter to quickly open the parent POM from your subproject.
You can also add dependencies to the parent POM that will be inherited by the subprojects.
Open Maven tool window to see that all changes made in the parent POM are reflected in subprojects.
Use the Maven settings to configure options such as Maven version, local repository, offline mode, and so on.
In the Settings dialog (CtrlAlt0S) , go to Build, Execution, Deployment| Maven.
tip
Click on the toolbar, in the Maven tool window to access the Maven settings.
On the Maven settings page, configure the available options and click OK to save the changes.
note
The Maven2 version is not bundled with IntelliJ IDEA. If you need to use it in your project, download and enable the Maven2 support plugin.
For a custom version, Download the needed Maven version on your computer.
Press CtrlAlt0S to open settings and then select Build, Execution, Deployment | Build Tools | Maven.
On the Maven settings page, in the Maven home path field, specify the location of the Maven custom version installation. For the Maven wrapper, select the use Maven wrapper option from the list. In this case the version of Maven defined in the .mvn
/wrapper file will be used./maven-wrapper.properties Click OK.
There are several places where you can change the JDK version that will affect not only your current project, but the whole application as well.
Changing the JDK version in the Project Structure dialog will only affect the current project.
In the main menu, go to File | Project Structure CtrlAltShift0S.
In the dialog that opens, in Project SDK, specify the JDK version and click OK to save the changes.
When IntelliJ IDEA runs Maven goals, it will use the JDK version specified for the Maven runner. By default, IntelliJ IDEA uses the project's JDK.
Changing the JDK for the Maven runner will only affect the current project.
In the Settings dialog (CtrlAlt0S) , go to Build, Execution, Deployment | Maven | Runner.
On the page that opens, in the JRE field, select the JDK version.
Changing the JDK version for the Maven importer will affect the whole application since it is a part of the Maven global settings. If you want to use the same JDK version as you use in your project for syncing or resolving dependencies, change the JDK version for the importer.
https://maven.apache.org/guides/introduction/introduction-to-dependency-mechanism.html#Dependency_Scope
In the Settings dialog (CtrlAlt0S) , go to Build, Execution, Deployment | Maven | Importing.
On the page that opens, in the JDK for importer field, select the same JDK version as you used in the Project Structure and click OK to save the changes.
Thanks for your feedback!