今天在使用jackson-dataformat-yaml
框架解析Yaml
文件的时候,解析过程中爆出了这样一个错误。
错误信息大致如下:
Exception in thread “main” java.lang.NoSuchMethodError: com.fasterxml.jackson.dataformat.yaml.YAMLFactory._createContentReference(Ljava/lang/Object;)Lcom/fasterxml/jackson/core/io/ContentReference;
at com.fasterxml.jackson.dataformat.yaml.YAMLFactory.createParser(YAMLFactory.java:353)
at com.fasterxml.jackson.dataformat.yaml.YAMLFactory.createParser(YAMLFactory.java:15)
at com.fasterxml.jackson.databind.ObjectMapper.readValue(ObjectMapper.java:3413)
这个错误产生的原因是因为,我们的项目同时引入了jackson-databind
框架,而jackson-databind
框架和jackson-dataformat-yaml
框架同时引入了一些jackson
相关的核心依赖,且这两个框架的核心依赖版本不一致,导致了报错。
使用Maven进行依赖分析,我们可以看到:
- 我们项目自己引入的
jackson-databind
框架,且版本较低。 jackson-dataformat-yaml
框架依赖了jackson-core
、jackson-databind
等依赖,且版本较高。- 根据Maven依赖原则,
jackson-databind
框架的依赖被优先使用(jackson-databind
框架在pom.xml
文件中被先声明也是导致依赖被优先使用的原因)。
根据以上的分析,我们可以得到两个解决方案:
根据最少依赖原则,我们可以直接注释
pom.xml
文件中的jackson-databind
框架依赖,这样项目就可以直接依赖jackson-dataformat-yaml
框架,且jackson-dataformat-yaml
框架中依赖了jackson-databind
项目,所以完全不影响项目的正常使用。【推荐该方案】在
pom.xml
文件中,将jackson-databind
框架依赖声明在jackson-dataformat-yaml
框架依赖之后。(这个方案本质上和注释jackson-databind
依赖区别不大,因为根据Maven依赖原则,这个依赖完全不会被使用。)