¿Qué es pom.xml (modelo de objetos de proyecto)? Ejemplo de pom.xml para que lo use en su proyecto web dinámico (Java/J2EE)

Publicado: 2021-06-25
¿Qué es pom.xml (modelo de objetos de proyecto)? Ejemplo de pom.xml para que lo use en su proyecto web dinámico

¿Qué es el archivo pom.xml?

POM significa Project Object Model . Es una unidad de trabajo fundamental en Maven. El archivo pom.xml contiene todas las instrucciones de configuración, dependencias, integración de complementos y configuración del proyecto.

Esta es la mejor manera de agregar dependencias de biblioteca a su proyecto. Copiar archivos .jar en la carpeta de recursos de su proyecto es una forma antigua de hacerlo

Comprendamos el archivo pom.xml en detalles.

El archivo pom.xml predeterminado más simple

Repasemos los elementos pom.xml:

Elemento Descripción
proyecto El elemento es la raíz del descriptor. En la tabla siguiente se enumeran todos los elementos secundarios posibles.
modeloVersión Declara a qué versión del descriptor de proyecto se ajusta este POM. Establézcalo en la versión 4.0.0.
Identificación del grupo Un identificador único universal para un proyecto. Es normal usar un nombre de paquete completo para distinguirlo de otros proyectos con un nombre similar (p. ej., org.apache.maven).
artefactoId El identificador de este artefacto que es único dentro del grupo proporcionado por el ID de grupo. Un artefacto es algo que es producido o utilizado por un proyecto. Los ejemplos de artefactos producidos por Maven para un proyecto incluyen: JAR, distribuciones fuente y binaria, y WAR.
versión La versión actual del artefacto producido por este proyecto.
comprender los elementos pom.xml

archivo pom.xml con elementos adicionales

archivo pom.xml con más elementos:

Elemento Descripción
embalaje El tipo de artefacto que produce este proyecto, por ejemplo, un pompón de oreja de guerra. Los complementos pueden crear su propio empaque y, por lo tanto, sus propios tipos de empaque, por lo que esta lista no contiene todos los tipos posibles.
nombre El nombre completo del proyecto.
URL La URL de la página de inicio del proyecto.
dependencias Este elemento describe todas las dependencias asociadas con un proyecto. Estas dependencias se utilizan para construir un classpath para su proyecto durante el proceso de construcción. Se descargan automáticamente de los repositorios definidos en este proyecto.
dependencia El grupo de proyecto que produjo la dependencia, por ejemplo, org.apache.maven.
construir Información requerida para construir el proyecto.
directoriofuente Este elemento especifica un directorio que contiene la fuente del proyecto. El sistema de construcción generado compilará la fuente en este directorio cuando se construya el proyecto. La ruta dada es relativa al descriptor del proyecto.
nombrefinal El nombre de archivo (excluyendo la extensión y sin información de ruta) al que se llamará el artefacto producido. El valor predeterminado es ${artifactId}-${version}.
complementos La lista de complementos a usar.
enchufar El ID de grupo del complemento en el repositorio.
alcance El alcance de la dependencia: compilación, tiempo de ejecución, prueba, sistema y proporcionado. Se utiliza para calcular los diversos classpaths utilizados para la compilación, las pruebas, etc. También ayuda a determinar qué artefactos incluir en una distribución de este proyecto.

Hemos publicado más de 700 tutoriales de Java en Crunchify y estamos usando archivos pom.xml desde el principio, incluidas las dependencias de Spring MVC.

En los últimos años, debido a la adición de más y más dependencias de bibliotecas, el archivo pom.xml del tutorial de Java de Crunchify ahora es más grande.

Aquí está nuestro archivo pom.xml actual para su referencia. Si lo copia y lo agrega a su proyecto, eso también funciona para usted.

archivo pom.xml que estamos usando para los tutoriales de Java de Crunchify

Espero que esto aclare qué es el archivo pom.xml y por qué lo usamos en cualquier proyecto J2EE de Java.

Avísame si tienes más preguntas.

Actualice Log4j a la última versión

CVE-2021-44228: Apache Log4j2 <= 2.14.1 Las características de JNDI utilizadas en la configuración, los mensajes de registro y los parámetros no protegen contra LDAP controlado por atacantes y otros puntos finales relacionados con JNDI.

A partir de log4j 2.16.0, este comportamiento se ha desactivado de forma predeterminada.