spring resteasy 开接口时,报错NoSuchMethodError: com.fasterxml.jackson.databind.ObjectWriter.getFactory() 的

本文解决在Spring中使用Resteasy开放接口时,因Jackson jar包版本过低导致的NoSuchMethodError错误。通过升级jackson-core、jackson-databind及jackson-jaxrs-json-provider到2.4.1版本成功解决问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原文地址:http://www.5ixiudou.com/portal/detailInfo/1000000005/231

编辑器:idea

报错现象:在使用reasteasy 在 spring 中开开放接口时,在postman中调用接口报错:NoSuchMethodError: com.fasterxml.jackson.databind.ObjectWriter.getFactory()。


报错原因:
    jackson jar包版本过低。


排查过程:
    1.判断是否是jar包冲突:首先看项目中引入了几个包含该类的jar包。ctrl+n,看到就引入了一个包含该类的jar包,应该不是jar包冲突。
    2.进一步判断是否是jar包冲突:进入jar包中的ObjectWriter类,查看是否是缺少getFactory()方法。经过查看,果真木有这个方法,看来不是冲突,而是确实缺少这个方法。
    3.基本确定是jar包版本的问题。一般会因为jar包版本过低造成这种情况。上网搜 databind json 版本,发现有更高的版本。修改maven依赖更高版本的jackson包,我是用 2.4.1版本解决的这个问题,依赖如下:
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-core</artifactId>
            <version>2.4.1</version>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.4.1</version>
        </dependency>
        <dependency>
            <groupId>com.fasterxml.jackson.jaxrs</groupId>
            <artifactId>jackson-jaxrs-json-provider</artifactId>
            <version>2.4.1</version>
            <exclusions>
                <exclusion>
                    <groupId>com.fasterxml.jackson.core</groupId>
                    <artifactId>jackson-annotations</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
    注意:可能jackson有更高版本的,但是是慎用,要看代码环境,有时过高的版本会出现其他问题。就选择一个中间版本就可以了。
    当然,如果没有使用maven,可以手动导入下面的jar包。如果需要其他版本的jar包,可以联系我。
    jar包下载地址:http://www.5ixiudou.com/portal/detailInfo/1000000005/231


    
注意事项:
    1.当发现jar包版本过低时,应当适当提高jar包版本,但不适宜太高。
    2.如果依赖其他模块,一定要确认其他模块中的jackson相关依赖的版本,最好不要只修改一部分依赖的版本。比如,我的core和databind是在 demo-core 模块下,provider是在 demo-web 模块下,这时不要只修改 demo-web 模块下的 pom.xml,demo-core中的也要进行修改。
    

更多内容,请关注我的个人网站:www.5ixiudou.com,大家共同学习,共同进步。

2025-05-27 17:29:45.743 ERROR 15325 --- [nio-8810-exec-4] [] [] org.jboss.resteasy.resteasy_jaxrs.i18n : RESTEASY002010: Failed to execute javax.ws.rs.NotSupportedException: RESTEASY003200: Could not find message body reader for type: class com.spotter.dtg.aetherflow.admin.adapter.web.request.liteChain.LiteUpdateFlowReq of content type: text/plain;charset=UTF-8 at org.jboss.resteasy.core.interception.ServerReaderInterceptorContext.throwReaderNotFound(ServerReaderInterceptorContext.java:53) ~[resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.core.interception.AbstractReaderInterceptorContext.getReader(AbstractReaderInterceptorContext.java:80) ~[resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.core.interception.AbstractReaderInterceptorContext.proceed(AbstractReaderInterceptorContext.java:53) ~[resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.core.MessageBodyParameterInjector.inject(MessageBodyParameterInjector.java:198) ~[resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.core.MethodInjectorImpl.injectArguments(MethodInjectorImpl.java:91) ~[resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.core.MethodInjectorImpl.invoke(MethodInjectorImpl.java:113) ~[resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.core.ResourceMethodInvoker.internalInvokeOnTarget(ResourceMethodInvoker.java:543) ~[resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.core.ResourceMethodInvoker.invokeOnTargetAfterFilter(ResourceMethodInvoker.java:432) ~[resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.core.ResourceMethodInvoker.lambda$invokeOnTarget$0(ResourceMethodInvoker.java:393) ~[resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.core.interception.PreMatchContainerRequestContext.filter(PreMatchContainerRequestContext.java:358) ~[resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.core.ResourceMethodInvoker.invokeOnTarget(ResourceMethodInvoker.java:395) ~[resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.core.ResourceMethodInvoker.invoke(ResourceMethodInvoker.java:364) ~[resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.core.ResourceMethodInvoker.invoke(ResourceMethodInvoker.java:337) ~[resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.core.SynchronousDispatcher.invoke(SynchronousDispatcher.java:440) [resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.core.SynchronousDispatcher.lambda$invoke$4(SynchronousDispatcher.java:229) [resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.core.SynchronousDispatcher.lambda$preprocess$0(SynchronousDispatcher.java:135) [resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.core.interception.PreMatchContainerRequestContext.filter(PreMatchContainerRequestContext.java:358) ~[resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.core.SynchronousDispatcher.preprocess(SynchronousDispatcher.java:138) [resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.core.SynchronousDispatcher.invoke(SynchronousDispatcher.java:215) [resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.plugins.server.servlet.ServletContainerDispatcher.service(ServletContainerDispatcher.java:245) ~[resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher.service(HttpServletDispatcher.java:61) ~[resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final] at org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher.service(HttpServletDispatcher.java:56) ~[resteasy-jaxrs-3.12.1.Final.jar:3.12.1.Final]
最新发布
05-28
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值