博客
关于我
java.lang.VerifyError: Stack map does not match the one at exception
阅读量:806 次
发布时间:2023-01-27

本文共 746 字,大约阅读时间需要 2 分钟。

在编写AOP程序时,遇到了JDK 11环境下的verifyError问题。verifyError提示“Stack map does not match the one at exception”,这通常是由于JVM在加载动态生成的类文件时对字节码进行校验失败所引起的。

JVM在加载类文件时会执行字节码校验,这一过程旨在确保字节码的安全性和一致性。如果类文件是使用javac编译生成的,通常不会出现verifyError。但当类文件由动态工具(如asm、cglib等)生成,或来源于第三方库时,可能会遇到校验失败的问题,这可能是由于字节码生成程序存在bug,也可能是由于JVM版本升级导致新增的校验条件。

对于这个问题,可以采取以下解决措施:

  • 禁止字节码校验:通过设置JVM启动时参数-noverify来禁用字节码校验,这可以让动态生成的类文件避开JVM的校验步骤。例如:
  • java -noverify YourMainClass
    1. 更换JVM实现:某些情况下,可以考虑更换基于 McCabe 的 JDK(如JDBC或PrivateDirectory),尤其是在遇到特定JVM版本的验证问题时。
    2. 在禁用校验时,需要注意以下几点:

      • 安全隐患:禁用校验可能会降低运行时的安全性,允许恶意代码执行。
      • 性能影响:校验机制的禁用会增加性能开销,影响应用的执行效率。
      • 兼容性问题:不同JVM实现可能对校验的实现方式有所不同,禁用校验可能导致其他问题。

      在实际操作中,应根据具体的应用场景权衡 performance 和 security 的权衡。同时,可以结合字节码生成工具进行审计,确保生成的字节码是正确无误的。此外,尽量使用那些已经通过广泛测试并被证明稳定性的动态类生成工具,以减少遇到类似问题的风险。

    转载地址:http://ybryk.baihongyu.com/

    你可能感兴趣的文章
    MySQL 查看有哪些表
    查看>>
    mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
    查看>>
    MySql 查询以逗号分隔的字符串的方法(正则)
    查看>>
    MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
    查看>>
    mysql 查询,正数降序排序,负数升序排序
    查看>>
    MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
    查看>>
    mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
    查看>>
    mysql 死锁(先delete 后insert)日志分析
    查看>>
    MySQL 死锁了,怎么办?
    查看>>
    MySQL 深度分页性能急剧下降,该如何优化?
    查看>>
    MySQL 深度分页性能急剧下降,该如何优化?
    查看>>
    MySQL 添加列,修改列,删除列
    查看>>
    mysql 添加索引
    查看>>
    MySQL 添加索引,删除索引及其用法
    查看>>
    MySQL 用 limit 为什么会影响性能?
    查看>>
    MySQL 用 limit 为什么会影响性能?有什么优化方案?
    查看>>
    MySQL 用户权限管理:授权、撤销、密码更新和用户删除(图文解析)
    查看>>
    mysql 用户管理和权限设置
    查看>>
    MySQL 的 varchar 水真的太深了!
    查看>>
    mysql 的GROUP_CONCAT函数的使用(group_by 如何显示分组之前的数据)
    查看>>