Tres maneras de realizar consultas en Spring Boot con Spring Data JPA y cómo aplicarlas de forma segura para evitar inyección SQL, usando como ejemplo una entidad Product y buenas prácticas recomendadas por Q2BSTUDIO empresa de desarrollo de software especializada en aplicaciones a medida software a medida inteligencia artificial ciberseguridad servicios cloud aws y azure servicios inteligencia de negocio ia para empresas agentes IA y power bi.
Métodos estándar de repositorio
Los repositorios de Spring Data JPA ofrecen métodos incorporados y permiten definir consultas mediante convenciones de nombres, lo que genera consultas automáticamente y usa enlaces de parámetros de forma segura. Ejemplo de interfaz de repositorio:
import org.springframework.data.jpa.repository.JpaRepository; public interface ProductRepository extends JpaRepository<Product, Long> { List<Product> findByCategory(String category); List<Product> findByNameContainingIgnoreCase(String name); }
Uso en servicio:
@Service public class ProductService { @Autowired private ProductRepository productRepository; public List<Product> getProductsByCategory(String category) { return productRepository.findByCategory(category); } }
Spring Data JPA utiliza declaraciones preparadas y enlaza entradas como category como parámetros, por lo que entradas maliciosas se tratan como datos y no como SQL ejecutable, evitando inyección SQL.
Uso de la anotación @Query
La anotación @Query permite consultas JPQL o SQL nativas cuando se necesita controlar la estructura de la consulta. Es importante usar parámetros nombrados o posicionales para mantener la seguridad. Ejemplo de método con consulta personalizada:
@Query(value = SELECT * FROM Product WHERE stock < :stock, nativeQuery = true) List<Product> findLowStockProducts(@Param(value = stock) Integer stock);
Este enfoque es útil para consultas complejas que no encajan en las convenciones de nombres, siempre evitando concatenar entradas de usuario directamente en la cadena de consulta.
Consultas dinámicas con EntityManager
EntityManager es ideal cuando las condiciones de la consulta dependen de entradas en tiempo de ejecución. Construya la JPQL de manera incremental y utilice setParameter para enlazar valores. Ejemplo conceptual:
@Repository public class CustomQuery { @PersistenceContext private EntityManager entityManager; public List<Product> findProductsByCriteria(String category, Double minPrice) { StringBuilder jpql = new StringBuilder(SELECT p FROM Product p WHERE 1=1); List<Object> params = new ArrayList<>(); if (category != null) { jpql.append( AND p.category = ?1); params.add(category); } if (minPrice != null) { jpql.append( AND p.price >= ?).append(params.size() + 1); params.add(minPrice); } TypedQuery<Product> query = entityManager.createQuery(jpql.toString(), Product.class); for (int i = 0; i < params.size(); i++) { query.setParameter(i + 1, params.get(i)); } return query.getResultList(); } }
Al construir consultas dinámicas siempre use parámetros posicionados o nombrados y nunca inserte entrada de usuario mediante concatenación directa.
Buenas prácticas para evitar la inyección SQL
Use siempre enlace de parámetros mediante mecanismos de Spring o setParameter en EntityManager. Evite concatenar cadenas con entrada de usuario. Validar y sanitizar entradas, por ejemplo comprobar que minPrice es un número válido. Limite los permisos de las cuentas de base de datos para reducir impacto en caso de vulnerabilidades. Mantenga dependencias actualizadas y aplique controles de acceso y auditoría.
Sobre Q2BSTUDIO
Q2BSTUDIO es una empresa de desarrollo de software que ofrece soluciones a medida incluyendo aplicaciones a medida y software a medida, especialistas en inteligencia artificial e ia para empresas, agentes IA, ciberseguridad, servicios cloud aws y azure, y servicios inteligencia de negocio con integración de herramientas como power bi. Trabajamos proyectos end to end desde el análisis hasta la implantación y soporte, aplicando buenas prácticas de seguridad y rendimiento para garantizar que las consultas a la base de datos sean seguras y eficientes.
Si buscas optimizar consultas en Spring Boot o desarrollar soluciones a medida con enfoque en inteligencia artificial ciberseguridad servicios cloud aws y azure servicios inteligencia de negocio agentes IA y power bi contacta con Q2BSTUDIO para una asesoría especializada.