Skip to main content

๐ŸŒฑ Spring Boot Interview Series – Q9 : REST API Development Part 1 ๐Ÿš€

๐ŸŒ Spring Boot REST API Development – Part 1 ๐Ÿš€

REST APIs are the backbone of modern apps, and Spring Boot makes building them fast, easy, and fun! In interviews, knowing why things happen is as important as writing code. ๐Ÿ’ก


48. Difference between @RestController and @Controller ๐Ÿท️

While @Controller renders views (like HTML), @RestController is shorthand for @Controller + @ResponseBody, automatically serializing return objects to JSON/XML. Surprise factor: it’s not new magic — just saves boilerplate! ✨

@Controller

public class WebController {

    @GetMapping("/home")

    public String home() {

        return "home"; // renders home.html

    }

}

@RestController

public class ApiController {

    @GetMapping("/api/user")

    public User getUser() {

        return new User("Anand", 30); // returns JSON

    }

}

Unknown Fact: @RestController uses HttpMessageConverters like MappingJackson2HttpMessageConverter under the hood. ๐Ÿงฉ

Common Mistake: Using @Controller for REST endpoints without @ResponseBody — leads to Spring searching for a template. ๐Ÿ˜ฑ


49. What is @ResponseBody and when is it needed? ๐Ÿ“ฆ

@ResponseBody tells Spring: write the method’s return object directly to HTTP response. Essential for @Controller REST endpoints. Mentioning this difference in interviews shows deep understanding. ๐Ÿ‘€

@Controller

public class ApiController {

    @GetMapping("/api/product")

    @ResponseBody

    public Product getProduct() {

        return new Product("Laptop", 1200);

    }

}

Unknown Fact: Works with any HttpMessageConverter — JSON, XML, YAML, or custom formats! ๐ŸŒŸ

Common Mistake: Forgetting @ResponseBody makes Spring look for a view template. ๐Ÿ˜‚


50. How does Spring Boot handle JSON serialization/deserialization? ๐Ÿ”„

Spring Boot uses Jackson by default to convert Java ↔ JSON automatically via @RequestBody and @ResponseBody. Bonus: it supports Java 8 date/time, Optionals, and nested objects out-of-the-box! ๐Ÿš€

@RestController

public class ApiController {

    @PostMapping("/api/users")

    public User createUser(@RequestBody User user) {

        return user; // auto-serialized

    }

}

Unknown Fact: Lazy-loaded JPA entities can trigger exceptions during serialization — watch out! ๐Ÿ‡

Common Mistake: Missing @RequestBody leads to query param binding instead of JSON. ๐Ÿชค


51. How to customize Jackson settings in Spring Boot ๐ŸŽจ

Customize globally via ObjectMapper bean or properties: control naming strategy, date formats, null handling, indentation. Interview tip: show how to change field names globally! ๐ŸŒˆ

@Bean

public ObjectMapper objectMapper() {

    ObjectMapper mapper = new ObjectMapper();

    mapper.setSerializationInclusion(JsonInclude.Include.NON_NULL);

    mapper.enable(SerializationFeature.INDENT_OUTPUT);

    mapper.disable(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES);

    mapper.setPropertyNamingStrategy(PropertyNamingStrategies.SNAKE_CASE);

    return mapper;

}

Unknown Fact: You can register custom serializers/deserializers — e.g., encrypt sensitive fields! ๐Ÿ”

Common Mistake: Multiple ObjectMappers without @Primary confuse Spring Boot autoconfiguration. ๐Ÿ˜ฌ


52. How to enable/disable specific REST endpoints ๐Ÿšฆ

Control endpoints (especially actuators) via management.endpoints.web.exposure.include/exclude or @ConditionalOnProperty. Critical in production to hide sensitive endpoints. ๐Ÿ”

management.endpoints.web.exposure.include=health,info

management.endpoints.web.exposure.exclude=beans,env

Unknown Fact: Conditional exposure can adapt endpoints dynamically per environment. ๐ŸŒ

Common Mistake: Leaving sensitive endpoints like /beans open — huge security risk! ๐Ÿ˜ฑ


53. How to handle exceptions globally in Spring Boot ๐Ÿ›ก️

In Spring Boot, centralized exception handling can be done in **two ways** depending on your controllers: MVC or REST. This prevents cluttering each controller with try-catch blocks and ensures consistent error responses across your application. ⚡

1️⃣ Using @ControllerAdvice (Spring MVC)

Works with @Controller endpoints. By default, it returns view names (HTML). To return JSON, add @ResponseBody on the handler method.

@ControllerAdvice
public class GlobalMvcExceptionHandler {

    @ExceptionHandler(ResourceNotFoundException.class)
    @ResponseBody  // needed for JSON
    public ResponseEntity<Map<String,String>> handleNotFound(ResourceNotFoundException ex){
        Map<String,String> error = new HashMap<>();
        error.put("timestamp", LocalDateTime.now().toString());
        error.put("message", ex.getMessage());
        return new ResponseEntity<>(error, HttpStatus.NOT_FOUND);
    }
}

Unknown Fact: You can target specific controllers using basePackages or assignableTypes in @ControllerAdvice. ๐ŸŽฏ

Common Mistake: Forgetting @ResponseBody for REST endpoints in MVC controllers leads to Spring trying to render a view — confusing for beginners! ๐Ÿ˜ฑ

2️⃣ Using @RestControllerAdvice (Spring REST)

@RestControllerAdvice is specialized for REST APIs and automatically returns JSON/XML responses for exceptions. No need for @ResponseBody on each method.

@RestControllerAdvice
public class GlobalRestExceptionHandler {

    @ExceptionHandler(ResourceNotFoundException.class)
    public ResponseEntity<Map<String,String>> handleNotFound(ResourceNotFoundException ex){
        Map<String,String> error = new HashMap<>();
        error.put("timestamp", LocalDateTime.now().toString());
        error.put("error", ex.getMessage());
        return new ResponseEntity<>(error, HttpStatus.NOT_FOUND);
    }
}

Unknown Fact: Perfect for REST APIs; works with multiple exception types and custom payloads like timestamps, error codes, and debug info. ๐Ÿง™‍♂️

Common Mistake: Using only @ControllerAdvice for REST endpoints without @ResponseBody leads to unexpected view rendering or 404 errors. ๐Ÿ˜…

✅ Key Takeaways

  • Use @ControllerAdvice for MVC controllers and HTML views.
  • Use @RestControllerAdvice for REST controllers; always returns JSON/XML.
  • Mixing both in a project is possible if you have MVC and REST controllers together.
  • This approach keeps exception handling clean, consistent, and interview-proof!

Wrapping Up ๐ŸŒŸ

REST API mastery in Spring Boot means more than returning JSON — it’s about **robust, maintainable, secure APIs**. Knowing hidden facts, pitfalls, and under-the-hood magic will make you shine in interviews and production alike. ๐Ÿง™‍♂️✨

Comments

Popular posts from this blog

๐Ÿ” Is final Really Final in Java? The Truth May Surprise You ๐Ÿ˜ฒ

๐Ÿ’ฌ “When I was exploring what to do and what not to do in Java, one small keyword caught my eye — final . I thought it meant: locked, sealed, frozen — like my fridge when I forget to defrost it.”   But guess what? Java has its own meaning of final… and it’s not always what you expect! ๐Ÿ˜… Let’s break it down together — with code, questions, confusion, jokes, and everything in between. ๐ŸŽฏ The Confusing Case: You Said It's Final... Then It Changed?! ๐Ÿซ  final List<String> names = new ArrayList <>(); names.add( "Anand" ); names.add( "Rahul" ); System.out.println(names); // [Anand, Rahul] ๐Ÿคฏ Hold on... that’s final , right?! So how on earth is it still changing ? Time to dive deeper... ๐Ÿง  Why Is It Designed Like This? Here’s the key secret: In Java, final applies to the reference , not the object it points to . Let’s decode this like a spy mission ๐Ÿ•ต️‍♂️: Imagine This: final List<String> names = new ArrayList <>(); Be...

๐ŸŒŸ My Journey – From Zero to Senior Java Tech Lead ๐ŸŒŸ

 There’s one thing I truly believe… If I can become a Java developer, then anyone in the world can. ๐Ÿ’ฏ Sounds crazy? Let me take you back. ๐Ÿ•“ Back in 2015… I had zero coding knowledge . Not just that — I had no interest in coding either. But life has its own plans. In 2016, I got a chance to move to Bangalore and joined a Java course at a training center. That’s where it all started — Every day, every session made me feel like: "Ohhh! Even I can be a developer!" That course didn’t just teach Java — it gave me confidence . ๐Ÿงช Two Life-Changing Incidents 1️⃣ The Interview That Wasn't Planned Halfway through my course, I had to urgently travel to Chennai to donate blood to a family member. After that emotional rollercoaster, I found myself reflecting on my skills and the future. The next day, as I was preparing for my move to Bangalore to complete the remaining four months of my course, I randomly thought — "Let me test my skills... let me just see...

๐ŸŽข Java Loops: Fun, Fear, and ForEach() Fails

๐ŸŒ€ Oops, I Looped It Again! — The Ultimate Java Loop Guide You Won't Forget “I remember this question from one of my early interviews — I was just 2 years into Java and the interviewer asked, ‘Which loop do you prefer and why?’” At first, I thought, “Duh! for-each is cleaner.” But then he grilled me with cases where it fails. ๐Ÿ˜ต That led me to explore all loop types, their powers, and their pitfalls. Let’s deep-dive into every major Java loop with examples &  real-world guidance so you'll never forget again. ๐Ÿ” Loop Type #1: Classic For Loop — “The Old Reliable” ✅ When to Use: You need an index You want to iterate in reverse You want full control over loop mechanics ✅ Good Example: List<String> names = List.of("A", "B", "C"); for (int i = 0; i < names.size(); i++) { System.out.println(i + ": " + names.get(i)); } ๐Ÿ”ฅ Reverse + Removal Example: List<String> item...