Dealing with "Xerces Hell" in Java/Maven?
Background
Xerces, a widely used XML parser in the Java ecosystem, poses significant challenges due to historical factors and packaging issues. The official Xerces binaries lack versioning, and the project is not uploaded to Maven Central officially. Additionally, the split of Xerces into multiple jars (xml-apis, xercesImpl) and the varying versioning practices by different parties have compounded the problem. This leads to conflicts and classloader issues when using Xerces in Maven environments.
Problems
Conflict Resolution
Maven's inability to resolve conflicts between different versions of the same artifact, even when published by different organizations, leads to situations where multiple Xerces dependencies are included, potentially resulting in classpath conflicts.
Classloader Hell
The inclusion of Xerces in both the JAXP reference implementation and servlet containers, combined with the potentially conflicting versions from Maven dependencies, creates a complex classloading scenario, requiring careful management to avoid classloader conflicts at runtime.
Solutions
Attempts to exclude or mark Xerces dependencies as provided can be challenging due to the multiple aliases and dependencies of third-party libraries and frameworks. However, a significant development has emerged:
Recent Update
In February 2013, a patched version of the Xerces build scripts was uploaded to fix the Maven Central upload issue. Xerces 2.11.0 JARs are now available in Maven Central, resolving the long-standing versioning and packaging problems.
This development significantly simplifies Xerces dependency management in Maven projects. Developers can now use the following dependency declaration to resolve Xerces correctly:
<dependency> <groupid>xerces</groupid> <artifactid>xercesImpl</artifactid> <version>2.11.0</version> </dependency>
This solution eliminates the need for fine-grained dependency control and complex tiered classloading mechanisms.
The above is the detailed content of How to Avoid \'Xerces Hell\' in Java/Maven?. For more information, please follow other related articles on the PHP Chinese website!

The article discusses using Maven and Gradle for Java project management, build automation, and dependency resolution, comparing their approaches and optimization strategies.

The article discusses creating and using custom Java libraries (JAR files) with proper versioning and dependency management, using tools like Maven and Gradle.

The article discusses implementing multi-level caching in Java using Caffeine and Guava Cache to enhance application performance. It covers setup, integration, and performance benefits, along with configuration and eviction policy management best pra

The article discusses using JPA for object-relational mapping with advanced features like caching and lazy loading. It covers setup, entity mapping, and best practices for optimizing performance while highlighting potential pitfalls.[159 characters]

Java's classloading involves loading, linking, and initializing classes using a hierarchical system with Bootstrap, Extension, and Application classloaders. The parent delegation model ensures core classes are loaded first, affecting custom class loa


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Dreamweaver Mac version
Visual web development tools

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool