Spring Boot - Get Started

. . 5 min read

display

Spring Boot is a popular framework that simplifies and accelerate the process of developing a java based application

What You Will build

You will build a Spring Boot web application.

What You Need

  • A favorite text editor or IDE
  • JDK 1.8 or later
  • Gradle 4+ or Maven 3.2+

Setup Project With Spring Initializr

  • Navigate to Spring initializr.

  • Define the project name example: spring-boot-get-started

  • Choose Project Maven and the language Java.

  • Choose Your Java version ex: 17

  • Click add dependencies and select:

    • Spring Web
  • Click Generate.

Unzip the Downloaded Zip and open the Project using your favorite text editor or IDE

Application class

The main class for our application, serve as an entry point for our Spring boot application

@SpringBootApplication
public class SpringBootGetStartedApplication {

    public static void main(String[] args) {
        SpringApplication.run(SpringBootGetStartedApplication.class, args);
    }

}

The class is annotated with @SpringBootApplication which is a combination of several annotation :

  • @EnableAutoConfiguration Attempting to auto-configure beans, usually applied to classes based on your classpath and what beans you have defined
  • @ComponentScan Sets up component scanning directives for any @Configuration @Component @Service.

SpringApplication.run() method to launch the spring boot application. once you lunch the app it will be running on port 8080, you can set it under the application.properties server.port=8081, This web application relies on annotation-based configuration, which means it's entirely Java-based, eliminating the need to manually configure the web application infrastructure. This approach allows you to focus more on the business logic

Web Application

under the src package create the class GreetingController

@RestController
public class GreetingController {

	@GetMapping("/")
	public String index() {
		return "Greetings from Nonestack!";
	}

}
  • The class is annotated with a @RestController, meaning it is ready to be used by Spring MVC to handle web requests.
  • Spring Boot use a singleton servlet than it will delegate the request to the corresponded @Controller or @RestController
  • @GetMapping maps the path / to the index() method. When call the endpoint http://localhost:8080/, the method returns text. That is because @RestController combines @Controller and @ResponseBody, two annotations that results in web requests returning data rather than a view.

Run the Application

To run the application, run the following command based on your project management

  • Maven ./mvnw spring-boot:run
  • Gradle ./gradlew bootRun

Test

Add the flowing test dependency to you pom.xml file

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-test</artifactId>
  <scope>test</scope>
</dependency>

If you use Gradle, add the following dependency to your build.gradle file

testImplementation('org.springframework.boot:spring-boot-starter-test')

Write the unit test GreetingControllerTest.java under the src/test/java/com/nonestack/springbootgetstarted folder

@SpringBootTest
@AutoConfigureMockMvc
public class GreetingControllerTest {

  @Autowired
  private MockMvc mvc;

  @Test
  public void getHello() throws Exception {
    mvc.perform(MockMvcRequestBuilders.get("/").accept(MediaType.APPLICATION_JSON))
            .andExpect(status().isOk())
            .andExpect(content().string(equalTo("Greetings from Nonestack!")));
  }
}

MockMvc, from Spring Test, allows you to send HTTP requests and check the results using builder classes. Use @AutoConfigureMockMvc and @SpringBootTest to inject a MockMvc instance. @SpringBootTest creates the full application context, while @WebMvcTest focuses on the web layers. Spring Boot automatically identifies the main application class, but you can override or narrow it down if needed.

Summary

Congratulations 🎉 ! You've created quick Spring Boot Web Application to get started.

Github

The tutorial can be found here on GitHub 👋

Blog

Check new tutorials on nonestack 👋

6
741

Recent articles

Spring Authorization Server - OAuth JWT

spring authorize server

This guide walks you through the process of building a Spring Boot Authorization Server JWT that uses Spring Security Security and Spring Security OAuth Resource. Applying the new way to configure Spring Authorization Server JWT without the Custom Filter

Continue reading
9 min read
.
981 views

Spring Data - JPA DataTable

spring data

This guide walks you through the process of building a Spring boot application that uses JPA DataTable.

Continue reading
10 min read
.
731 views

Spring Web - Rest Client

spring boot

Spring Framework introduces RestClient a new Fluent API to make synchronous HTTP requests

Continue reading
4 min read
.
925 views

Spring Security - Basic Authentication

spring security

This guide walks you through the process of building a Spring boot application that uses Spring Security and Spring Data JPA. Applying the new way to configure Spring Security without the WebSecurityConfigurerAdapter

Continue reading
6 min read
.
781 views