我在fabric8/java-alpine-openjdk11-jre:1.6.5
容器中得到了UnmapableCharacterException。如何修复此异常?
java.nio.charset.UnmappableCharacterException: Input length = 1
at java.base/java.nio.charset.CoderResult.throwException(CoderResult.java:275)
at java.base/sun.nio.cs.StreamEncoder.implWrite(StreamEncoder.java:306)
at java.base/sun.nio.cs.StreamEncoder.implWrite(StreamEncoder.java:281)
at java.base/sun.nio.cs.StreamEncoder.write(StreamEncoder.java:125)
应用程序上下文:
我的应用程序是带有Quarkus Framework的web api应用程序,基本上我使用UTF-8编码,但在某些情况下我需要使用其他编码,如MS932 (Windows-31j)
。
当我在机器上运行应用程序时(不是在容器中,使用./gradlew quarkusDev
(,我可以用这些特定的编码获得响应,但在容器中我遇到了上面的异常。
最近,我将框架Jersey更改为Quarkus,将tomcat:8.5-jdk11-openjdk-slim
容器更改为fabric8/java-alpine-openjdk11-jre:1.6.5
容器。
我确信带有tomcat:8.5-jdk11-openjdk-slim
的Jersey毫无例外地做出了回应,所以我稍后会尝试使用openjdk11瘦图像,但我喜欢fabric8的容器,所以我想解决这个问题并继续使用它。
检测到的结果:
我试图将这些特定编码更改为UTF-8
或UTF-16
,响应正常,但不仅是MS932
,还有SJIS
、GBK
和其他扩展编码集返回异常。
在这种情况下,我想这些异常与Extended Encoding Set
和fabric8的容器图像有关。
环境信息和Dockerfile:
以下是我的Dockerfile部分(它基于Quarkus生成的Dockerfle(:
FROM fabric8/java-alpine-openjdk11-jre:1.6.5
ENV JAVA_OPTIONS="-Dquarkus.http.host=0.0.0.0 -Djava.util.logging.manager=org.jboss.logmanager.LogManager"
ENV AB_ENABLED=jmx_exporter
# Be prepared for running in OpenShift too
RUN adduser -G root --no-create-home --disabled-password 1001
&& chown -R 1001 /deployments
&& chmod -R "g+rwX" /deployments
&& chown -R 1001:root /deployments
COPY --from=build /home/gradle/project/build/lib/* /deployments/lib/
COPY --from=build /home/gradle/project/build/*-runner.jar /deployments/app.jar
EXPOSE 8080
# run with user 1001
USER 1001
- 操作系统:Debian GNU/Linux 10
- Docker版本:18.09.1
参考
- 支持的编码
- UnmapableCharacterException(Java SE 11&JDK 11(
我们找到了解决方案。
不幸的是,这不是Quarkus、Fabric8和Java的问题,只是数据(字符(的问题。
最近更新了数据。它包含一些MS932
或其他编码无法显示的字符,但UTF-8
可以显示。这就造成了这个问题。
令人尴尬,但问题得到了解决。