Creating your Spring Boot Project
Using the IntelliJ IDEA New Project Wizard to create your Spring project and select dependencies.
Create your Spring Project
We’ll use IntelliJ IDEA Ultimate for this tutorial because we want to create a new project using Spring Initializr. This functionality is only available with IntelliJ IDEA Ultimate. This tutorial is based off Building an Application with Spring Boot.
- If you’re in an IntelliJ IDEA project already, select File >Project. Alternatively click the New Project button on the Welcome screen.
- Select Spring Initializr on the left-hand side and then enter the following options:
Your page should look similar to this:
Click Next.
- The next page is where you can configure your Spring Initializr project and add the required dependencies. We’re going to keep it really simple for this project as we just want to serve the string «Hello World» locally in our browser. Let’s start typing in Web and see what options we get. This will show you all dependencies that relate to Web development, we want the first one, Spring Web. Alternatively, you can expand the Web node (second from the top) and select Spring Web. That’s all you need to do here.
One thing to note here is that it’s really easy to add dependencies to your Spring project once you have created it. You should only ever add what you know you’ll need at this step. It’s easier to add dependencies at a later date than it is to remove dependencies that you may, or may not, be relying on at a future date!
Your page should look like this, depending on how you searched for Spring Web:
Click Finish.
That’s all we have to do to get our basic Spring project set up in IntelliJ IDEA. In the next step we’ll take a look at what has been automatically created for you, and most importantly, why.
Tutorial: Create your first Spring application
This tutorial describes how to create and run a Spring application in IntelliJ IDEA. It will be a Spring Boot Maven project generated by Spring Initializr. This is the quickest way to create a Spring application, and IntelliJ IDEA provides a dedicated project wizard for it. You will learn how to expose an HTTP endpoint and map it to a method that returns a greeting to the user when accessed through a web browser.
Create a new Spring Boot project
- From the main menu, select File | New | Project .
- In the left pane of the New Project wizard, select Spring Initializr .
- Specify a name for the project: spring-boot-tutorial . From the JDK list, select Download JDK and download the latest version of Oracle OpenJDK. Select the latest Java version. Click Next to continue.
- Select the Spring Web dependency under Web . This dependency is required for any web application that uses Spring MVC. Click Create to generate and set up the project.
Add a method that sends a greeting
Spring Initializr creates a class with the main() method to bootstrap your Spring application. In this tutorial, we’ll add the sayHello() method directly to this class.
- Open the SpringBootTutorialApplication.java file under src/main/java/com/example/springboottutorial . IntelliJ IDEA provides the Go to File action to quickly find and open files. From the main menu, select Navigate | File or press Ctrl+Shift+N , start typing the name of the file and select it from the list.
- Add the sayHello() method with all of the necessary annotations and imports so that the file looks like this:
package com.example.springboottutorial; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; @SpringBootApplication @RestController public class SpringBootTutorialApplication < public static void main(String[] args) < SpringApplication.run(SpringBootTutorialApplication.class, args); >@GetMapping(«/hello») public String sayHello(@RequestParam(value = «myName», defaultValue = «World») String name) < return String.format("Hello %s!", name); >>
- The @RestController annotation marks the SpringBootTutorialApplication class as a request handler (a REST controller).
- The @GetMapping(«/hello») annotation maps the sayHello() method to GET requests for /hello .
- The @RequestParam annotation maps the name method parameter to the myName web request parameter. If you don’t provide the myName parameter in your web request, it will default to World .
Run your Spring application
IntelliJ IDEA creates a Spring Boot run configuration that you can use to run your new Spring application.
- If the run configuration is selected, press Shift+F10 . You can also use the icon in the gutter of the SpringBootTutorialApplication.java file next to the class declaration or the main() method declaration.
By default, IntelliJ IDEA shows your running Spring Boot application in the Run tool window.
The Console tab shows the output of Spring log messages. By default, the built-in Apache Tomcat server is listening on port 8080. Open your web browser and go to http://localhost:8080/hello. If you did everything right, you should see your application respond with Hello World! .
You can quickly open this URL in your browser using the dedicated intention action: place the caret on the controller URL mapping (such as /hello ), press Alt+Enter , and select Open in web browser .
This is the default generic response. You can provide a parameter in your web request to let the application know how to greet you properly. For example, try http://localhost:8080/hello?myName=Human.
Add a home page
The created Spring Boot application has one endpoint available at /hello. However, if you open the root context of your application at http://localhost:8080/, you will get an error because there is no root resource defined. Let’s add a static HTML home page with links to your endpoint.
- Create the index.html file under /src/main/resources/static/ . In the Project tool window, right-click the /src/main/resources/static/ directory, select New | HTML File , specify the name index.html , and press Enter .
- Modify the default template or replace it with the following HTML code:
Now your application will serve index.html as the root resource at http://localhost:8080/.
What’s next?
This simple application demonstrates how to get started with Spring. To learn how IntelliJ IDEA helps you write your code and manage the application at runtime, see the next tutorial, which focuses on more advanced Spring support features.