大佬们帮忙看看老项目一个主键 id 报 Java .lang.NoSuchMethodError 的错误如何解决 - V2EX
jiobanma
V2EX    Java

大佬们帮忙看看老项目一个主键 id 报 Java .lang.NoSuchMethodError 的错误如何解决

  •  
  •   jiobanma
    banmajio Mar 1, 2022 2239 views
    This topic created in 1533 days ago, the information mentioned may be changed or developed.

    1.老项目使用 hibernate 的框架,entry 层主键 id 使用的是 Integer 类型.代码如下:

     ... @Id @GeneratedValue(strategy=GenerationType.IDENTITY) public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } ... 

    2.接口里面调用 getId 的时候会报 java.lang.NoSuchMethodError 的错误.

     adviserChanges.setService_log_id(serviceLog.getId()); 

    3.报错信息如下:

    java.lang.NoSuchMethodError:cn.xxx.xxx.xxx.modules.studyservice.entity.ServiceLog.getId()I atcn.xxx.xxx.bj.modules.auslocal.service.AssignBigClassStudentService.assignAdviser(AssignBigClassStudentService.java:371) atcn.xxx.bpm.bj.modules.auslocal.service.AssignBigClassStudentService$$FastClassByCGLIB$$d542d115.invoke(<generated>) 

    4.刚开始猜测是不是因为编译有问题,后来反编译了.class 文件,发现反编译之后是有 getId 这个方法的. 而且测试环境和本地都是好使得,但是线上就出问题了.

    描述的也许不是很清楚,大家见谅! 大佬帮忙看看给点建议!!!

    14 replies    2022-03-01 18:01:18 +08:00
    TtTtTtT
        1
    TtTtTtT  
       Mar 1, 2022
    .getId()I 里的 I 是基础类型,你的 Java 代码是包装类。怎么改就布吉岛了。。
    Jooooooooo
        2
    Jooooooooo  
       Mar 1, 2022
    包冲突了, 你全局搜搜 modules.studyservice.entity.ServiceLog 这个是不是别的 jar 也有这个路径的方法.
    jiobanma
        3
    jiobanma  
    OP
       Mar 1, 2022
    @Jooooooooo 这个项目只有一个 jar,不会出现这种问题的吧
    @TtTtTtT 但是您看我定义的属性使用 Integer 定义的,不是用基本数据类型(int)定义的
    Jooooooooo
        4
    Jooooooooo  
       Mar 1, 2022
    @jiobanma 说的是依赖的 jar
    wolfie
        5
    wolfie  
       Mar 1, 2022
    用 arthas 运行时反编译
    jiobanma
        6
    jiobanma  
    OP
       Mar 1, 2022
    @Jooooooooo 查过了 没有其他地方使用
    jiobanma
        7
    jiobanma  
    OP
       Mar 1, 2022
    jiobanma
        8
    jiobanma  
    OP
       Mar 1, 2022
    @Jooooooooo
    @TtTtTtT
    @wolfie

    有没有可能是 改动了 ServiceLog 这个 entity 的 id 数据类型(之前是 int 的),但是 service 层没有代码改动, service 层的.class 文件没有重新编译,但是 entity 重新编译了,所以导致的.
    Junzhou
        9
    Junzhou  
       Mar 1, 2022
    mvn clean ,然后重新打包。
    lsk569937453
        10
    lsk569937453  
       Mar 1, 2022
    把 target 目录删了,重新编译一下项目
    mosliu
        11
    mosliu  
       Mar 1, 2022
    一般整体重新编译重新部署最简单。

    另外 检查下调用的包名 和 getId 的包名确定一致么
    mosliu
        12
    mosliu  
       Mar 1, 2022
    还有看看 jdk 版本是否兼容?
    考虑 jdk9+的模块化特性 没暴露?
    chenshun00
        13
    chenshun00  
       Mar 1, 2022
    去 lib 目录看看有没有重复的 jar 包吧,一般都是这个原因,或者是加载到了别人的类
    jiobanma
        14
    jiobanma  
    OP
       Mar 1, 2022
    @TtTtTtT
    @Jooooooooo
    @wolfie
    @Junzhou
    @lsk569937453
    @mosliu
    @chenshun00

    感谢各位大佬,基本确定问题了,线上的 jenkins 打包的脚本有问题,应该是 mvn 那边只对修改过的类进行编译,并没对引用的类进行编译导致的.
    About     Help     Advertise     Blog     API     FAQ     Solana     3297 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 759ms UTC 14:08 PVG 22:08 LAX 07:08 JFK 10:08
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86