Returning Entities vs DTOs in Spring Boot Controllers

🚫 Returning JPA Entities directly from a Spring Boot controller is convenient… until it breaks in production. Here’s why I prefer DTOs over Entities in REST APIs: - Entities are built for persistence (relationships, lazy loading, JPA annotations) — not for API responses. - Returning Entities can trigger serialization issues like `LazyInitializationException` when Jackson touches lazy fields. - Entities may accidentally expose internal/sensitive fields (passwords, roles, audit columns). - DTOs keep the API contract stable even when the database model changes. Quick example: // DTO public record UserDto(Long id, String name, String email) {} // Controller @GetMapping("/users/{id}") public UserDto getUser(@PathVariable Long id) { User user = userService.getUser(id); return new UserDto(user.getId(), user.getName(), user.getEmail()); } Do you currently return Entities directly from Controllers, or are you mapping to DTOs already? #Java #SpringBoot #ReactJS #FullStack #Coding #BackendDevelopment #RESTAPI

To view or add a comment, sign in

Explore content categories