DEV Community

Cover image for Java Spring Boot for Beginners: Part 2: Diving into Project Structure, REST Controllers, and Request Handling
Alexander the dev
Alexander the dev

Posted on

Java Spring Boot for Beginners: Part 2: Diving into Project Structure, REST Controllers, and Request Handling

Welcome to the second installment of our "Java Spring Boot for Beginners" series. If you are eager to enhance your understanding of Java Spring Boot, you're in the right place. My name is Alex, and today we'll be building on what we've learned in the previous session. We're set to delve into project structure organization, develop REST controllers, and handle various HTTP requests.

If you prefer to watch the tutorial you can do so here:https://youtu.be/jAc7SSmuV2I
also, part 1 is here: https://youtu.be/lIr1tN5gTN0

Understanding Project Structure

Having a well-organized project structure is crucial for the maintainability and readability of Java code. Think of it as a neatly arranged library—it makes finding what you need much easier. Our main Java code resides in the source folder, which contains two key folders: main and test. The main package encompasses the primary components of the application, including the com.tutorials.library.Management package, which contains the all-important application entry point.

Our Java project is typically segmented into four types: Controller, Model, Repository, and Service. Let’s explore what these mean:

  • Controller: Handles incoming requests.
  • Model: Defines data models such as Book and User.
  • Repository: Includes interfaces for database operations.
  • Service: Encompasses the business logic of the application.

Creating REST Controllers

In this session, we're focusing on the Model and Controller. To start, we create a controller class named BookController. Within Spring Boot, a controller is responsible for handling user requests. By adding the @RestController annotation, we inform Spring Boot that this class is meant to handle HTTP requests.

For example, the @GetMapping annotation is used to map HTTP GET requests to a specific handler method, like our getBooks method. This method returns a list of books—initially just a placeholder string, but it demonstrates how the pattern works.

Handling HTTP Requests with Postman

To effectively test all HTTP methods, beyond just GET, you’ll need a tool like Postman. Postman allows us to send HTTP requests and interact with our running service more dynamically than a browser alone, which typically handles only GET requests.

Here's a brief look at the main HTTP methods:

  • GET: Retrieve information, such as listing books.
  • POST: Create new resources, like a new book entry.
  • PUT: Update existing resources, such as a book title.
  • DELETE: Remove resources, like deleting a book from the database.

By following these methods, we efficiently push and handle data within our Java Spring Boot application.

Building the Book Model

Next, we create a Book class to define our data model. This class has three properties: ID, title, and author. Each property requires getter and setter methods to manipulate data consistently.

Adding Functionality with Controllers

We expand our BookController to implement methods for adding, updating, and deleting books. With @PostMapping, we create a new book entry from a JSON-formatted request body. Similarly, with @PutMapping, we update an existing book, and with @DeleteMapping, we remove a book by ID.

Testing and Debugging

Finally, learning to debug is key. Running your application in debug mode and setting breakpoints helps you inspect and troubleshoot potential issues effectively. Postman aids in validating requests sent to your service, enhancing the testing process.

In our next episode, we'll explore dependency injections and components—integral concepts in Spring Boot—and further refine our library management tool. Until then, happy coding! If you have questions, feel free to comment below or reach out via social media.

See you in the next session! Happy coding, and goodbye for now.

Top comments (0)