Ir al contenido principal

Inyección de dependencias en Java

 Inyección de dependencias en Java

Consiste en pasar la dependencia en la clase que lo va a utilizar en lugar de crearla internamente dentro de esa clase esto con el fin de no acoplar la clase a la implementación que esta utilizando. 

Inversión de control: es un framework quien toma control de los objetos. En este caso Spring. El cual se encarga de crear y administrar instancias de objetos que se conocen como builds o componentes. Entonces Spring usa la notación @Autowired para la inyección de dependencias.

Por lo tanto en Spring cuando estamos usando nuestras interfaces en el repositorio correspondiente es necesario asignarles la notación que te mencioné: @Auatowired, de esta manera le damos el control para que cree esas instancias:


@Autowired
private ProductoCrudRepository productoCrudRepository;

@Autowired
private ProductMapper mapper;


Asi nos evitamos crear objetos manualmente ya que es una mala práctica y estaríamos violando el principio de inyección de dependencias, si no sabes porque no es una buena práctica aqui te lo explico: 


Forma incorrecta: 

public class ProductoRepository { // Creando instancias manualmente - MAL private ProductoCrudRepository repository = new ProductoCrudRepository(); private ProductMapper mapper = new ProductMapper(); }

Forma correcta (siguiendo DI):

@Repository public class ProductoRepository { // Spring se encarga de la inyección - BIEN private final ProductoCrudRepository repository; private final ProductMapper mapper; // Constructor injection (incluso mejor que @Autowired) public ProductoRepository(ProductoCrudRepository repository, ProductMapper mapper) { this.repository = repository; this.mapper = mapper; } }


Otra forma correcta y práctica:


@Autowired
private ProductoCrudRepository productoCrudRepository;

@Autowired
private ProductMapper mapper;

¿Por qué la primera forma viola el principio de DI?

  1. Alta acoplamiento: La clase está creando sus propias dependencias
  2. Difícil de testear: No podemos inyectar mocks fácilmente
  3. Control directo: La clase controla la creación de sus dependencias en lugar de recibirlas

¿Por qué la segunda forma es mejor?

  1. Bajo acoplamiento: La clase no sabe cómo se crean sus dependencias
  2. Fácil de testear: Podemos inyectar mocks para pruebas
  3. Inversión de Control: Spring controla la creación y ciclo de vida de las dependencias


Comentarios

Entradas más populares de este blog

Arquitectura N-Capas GUÍA COMPLETA .NET Core

Entendiendo la Arquitectura Limpia (Clean Architecture) en .NET: Una Guía Completa La Arquitectura Limpia, también conocida como arquitectura N-Capas, es un patrón de diseño que nos ayuda a crear aplicaciones mantenibles, testables y escalables. En este artículo, exploraremos en detalle cómo implementar esta arquitectura en un proyecto .NET. Si quieres entenderlo más fácil y con código, te dejo este otro artículo:   Arquitectura Limpia explicado con patitos 🐤 ¿Qué es la Arquitectura Limpia? La Arquitectura Limpia es un conjunto de principios de diseño que nos ayuda a separar las responsabilidades en diferentes capas de nuestra aplicación. Cada capa tiene una responsabilidad específica y se comunica con las otras capas a través de interfaces bien definidas. Estructura del Proyecto Una típica estructura de proyecto en Arquitectura Limpia se ve así: ├── Controllers/ │   └── ProductController.cs ├── Domain/ │   ├── Models/ │   └── DTOs/ ├── Repository/ │...

Archivo Application.properties en SPRING BOOT

  Guía Completa: Application.properties en Spring Boot El archivo application.properties es una pieza fundamental en aplicaciones Spring Boot, actuando como el centro de configuración para todo tu proyecto. En esta guía, exploraremos sus características principales y cómo aprovecharlo al máximo. ¿Qué es application.properties? Es un archivo de configuración que permite definir diferentes parámetros y valores para tu aplicación Spring Boot sin necesidad de modificar el código fuente. Se ubica en src/main/resources y Spring Boot lo lee automáticamente al iniciar. Configuraciones Esenciales Configuración del Servidor # Puerto del servidor server.port = 8080 # Contexto de la aplicación server.servlet.context-path = /miapp Conexión a Base de Datos # MySQL spring.datasource.url = jdbc:mysql://localhost:3306/mibasededatos spring.datasource.username = usuario spring.datasource.password = contraseña spring.datasource.driver-class-name = com.mysql.cj.jdbc.Driver JPA y Hibernat...

Implementar SpringDoc OpenAPI |Swagger en Java Spring en 2 PASOS

 Implementar Swagger en Java Spring  Te ayudaré a crear una introducción atractiva para tu blog sobre la implementación de Swagger en Java Spring. En el dinámico mundo del desarrollo de APIs REST, la documentación clara y accesible se ha convertido en un elemento crucial para el éxito de cualquier proyecto. Swagger, también conocido como OpenAPI, se ha establecido como el estándar de facto para documentar APIs de manera elegante y eficiente. Cuando se combina con Spring Framework, uno de los frameworks más populares en el ecosistema Java, obtenemos una poderosa herramienta que no solo mejora la documentación de nuestras APIs, sino que también facilita enormemente su prueba y mantenimiento. En este artículo, exploraremos paso a paso cómo integrar Swagger en tus aplicaciones Java Spring, transformando la tediosa tarea de documentar APIs en un proceso fluido y automatizado. Ya seas un desarrollador experimentado buscando optimizar tu flujo de trabajo o estés comenzando tu viaje...