Reflections 0.9.12 Caused by: java.lang.IllegalStateException: zip file closed

8 篇文章 0 订阅
5 篇文章 0 订阅

在spring项目中使用发射框架 reflections 0.9.12 时,在windows上进行测试时候,不存在问题,但是发布部署到linux上进行运行测试,查看日志发现以下问题:

Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [x.x.x.SerializedTypeNameResolver]: Factory method 'serializedTypeNameResolver' threw exception; nested exception is java.lang.IllegalStateException: zip file closed
	at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:185) ~[spring-beans-5.2.3.RELEASE.jar!/:5.2.3.RELEASE]
	at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:651) ~[spring-beans-5.2.3.RELEASE.jar!/:5.2.3.RELEASE]
	... 95 common frames omitted
Caused by: java.lang.IllegalStateException: zip file closed
	at java.base/java.util.zip.ZipFile.ensureOpen(ZipFile.java:915) ~[na:na]
	at java.base/java.util.zip.ZipFile.stream(ZipFile.java:647) ~[na:na]
	at java.base/java.util.zip.ZipFile$1.stream(ZipFile.java:1131) ~[na:na]
	at java.base/java.util.jar.JarFile.stream(JarFile.java:534) ~[na:na]
	at org.reflections.vfs.ZipDir.lambda$getFiles$2(ZipDir.java:21) ~[reflections-0.9.12.jar!/:na]
	at org.reflections.Reflections.scan(Reflections.java:260) ~[reflections-0.9.12.jar!/:na]
	at org.reflections.Reflections.scan(Reflections.java:216) ~[reflections-0.9.12.jar!/:na]
	at org.reflections.Reflections.<init>(Reflections.java:137) ~[reflections-0.9.12.jar!/:na]
	at org.reflections.Reflections.<init>(Reflections.java:182) ~[reflections-0.9.12.jar!/:na]
	at org.reflections.Reflections.<init>(Reflections.java:155) ~[reflections-0.9.12.jar!/:na]
	at x.x.x.serializedTypeNameResolver.getTypesForName(SerializedTypeNameResolver.java:44) ~[integration-axondb-11.369.0.jar!/:11.369.0]
	at x.x.x.serializedTypeNameResolver.<init>(GSerializedTypeNameResolver.java:23) ~[integration-axondb-11.369.0.jar!/:11.369.0]
	at x.x.x.serializedTypeNameResolver(AxonServerSharedConfiguration.java:115) ~[integration-axondb-11.369.0.jar!/:11.369.0]

 在github查找问题原因,发现反射框架0.9.12,在linux会存在bug,需要降级到0.9.11才能使用,降级后运行测试成功。

 github参考地址:https://github.com/ronmamo/reflections/issues/279

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
注:下文中的 *** 代表文件名中的组件名称。 # 包含: 中文-英文对照文档:【***-javadoc-API文档-中文(简体)-英语-对照版.zip】 jar包下载地址:【***.jar下载地址(官方地址+国内镜像地址).txt】 Maven依赖:【***.jar Maven依赖信息(可用于项目pom.xml).txt】 Gradle依赖:【***.jar Gradle依赖信息(可用于项目build.gradle).txt】 源代码下载地址:【***-sources.jar下载地址(官方地址+国内镜像地址).txt】 # 本文件关键字: 中文-英文对照文档,中英对照文档,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压 【***.jar中文文档.zip】,再解压其中的 【***-javadoc-API文档-中文(简体)版.zip】,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·本文档为双语同时展示,一行原文、一行译文,可逐行对照,避免了原文/译文来回切换的麻烦; ·有原文可参照,不再担心翻译偏差误导; ·边学技术、边学英语。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;
### 回答1: 这个错误信息指的是在使用Reflections库时,无法从给定的URL中创建Vfs.Dir对象,所以程序会忽略这个异常并继续运行。 Reflections是一个用于在运行时反射Java代码的库。Vfs.Dir是Reflections库中用于表示虚拟文件系统目录的对象。如果无法从给定的URL中创建Vfs.Dir对象,可能是由于URL不正确或所指定的资源不存在,或者由于某种原因无法访问该资源。 要解决这个问题,可以尝试检查给定的URL是否正确,确保指定的资源存在并可以访问。如果这不能解决问题,可以尝试检查日志以了解更多信息,或者尝试在程序中捕获并处理这个异常。 ### 回答2: [org.reflections.Reflections] 抛出的异常表示无法根据给定的 URL 创建 Vfs.Dir。这可能是由于 URL 指向的资源无效或不存在导致的。在此情况下,Reflections 将忽略异常并继续执行,可能会影响到后续的操作和功能。 Reflections 是一个 Java 库,用于在运行时扫描和获取 Class、Method、Field 等的元数据。它依赖于 VFS(Virtual File System)来访问和解析不同类型的资源。VFS 提供了一种抽象的文件系统接口,可以统一处理来自不同来源的资源。 当 Reflections 尝试根据给定的 URL 创建 Vfs.Dir 时,它首先验证 URL 是否有效,并尝试解析其中包含的资源。如果 URL 无效或指向不存在的资源,就会抛出上述异常。为了避免中断程序流程,Reflections 选择忽略该异常,继续执行其他操作。这可能会导致在后续的扫描过程中缺失一些资源,或者无法正常解析某些类文件等。 如何解决这个问题需要根据具体情况而定。首先,我们应该检查给定的 URL 是否正确,并确保资源是存在并可以访问的。如果 URL 无误,但是仍然出现异常,可以尝试更新 Reflections 或 VFS 的版本,以确保使用最新的修复和改进。还可以查看 Reflections 和 VFS 的文档、问题跟踪和讨论,以了解是否有类似的报告和解决方案。 总之,[org.reflections.Reflections] 无法创建 Vfs.Dir from url 的异常表示 Reflections 无法根据给定的 URL 访问和解析资源。尽管它选择忽略该异常并继续执行,但可能会影响到后续的操作和功能。我们需要检查 URL 的有效性,更新相关库的版本,并参考文档和社区来解决这个问题。 ### 回答3: [org.reflections.Reflections]无法从URL创建Vfs.Dir。忽略异常并继续。 这个问题通常出现在使用Reflections库时,当尝试创建Vfs.Dir对象时,出现了异常。Reflections库是一个Java库,用于扫描和获取代码中的注解和类信息。 出现该异常的原因可以是URL参数无效或无法解析。可能的原因包括传递了无效的URL参数、URL不符合格式要求或无法从URL解析目录。 为了解决此问题,可以采取以下步骤: 1. 检查传递给Reflections库的URL参数是否正确。确保URL参数指向一个有效的目录。 2. 如果URL参数是一个本地文件系统路径,请确保路径存在且可访问。在某些情况下,可能会因为没有访问权限或路径不存在而无法创建Vfs.Dir对象。 3. 如果URL参数是一个网络地址,确保网络连接正常,并确保URL指向的资源在网络上是可访问的。 4. 检查URL的格式是否正确。URL应该采用标准格式,例如"http://example.com"或"file:/path/to/directory"。 5. 确保Reflections库的版本是最新的,可能存在旧版库中的bug已经修复。 6. 如果问题仍然存在,并且您不需要Reflections库的某些功能,可以考虑使用其他类扫描和反射库,例如Java的标准反射库或Google的Guava库。 总之,当看到[org.reflections.Reflections]无法创建Vfs.Dir from url的异常时,需要检查URL参数是否正确、目标资源是否存在和可访问,并确保Reflections库版本最新。如果问题仍然存在,可以考虑使用其他类扫描和反射库。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值