gpt4 book ai didi

java - 启动 Tomcat 时出错 - 外部参数实体 "%[dtd];"“在标记后有字符

转载 作者:行者123 更新时间:2023-11-28 23:06:49 26 4
gpt4 key购买 nike

我有一个我无法弄清楚的错误。

基本上,正在运行的网络应用程序没有任何变化(除了可能涌入的数据)。它突然死了。

访问该站点时,我看到 HTTP 状态 500 错误和 NullPointerException。我认为这是因为我的本地主机日志中的先前错误;

严重:Servlet 抛出 load() 异常
javax.servlet.UnavailableException: org.xml.sax.SAXParseException: 外部参数实体“%[dtd];”标记后有字符。
在 org.apache.struts.action.ActionServlet.init(ActionServlet.java:402)
在 javax.servlet.GenericServlet.init(GenericServlet.java:212)
在 org.apache.catalina.core.StandardWrapper.loadServlet(StandardWrapper.java:1173)
在 org.apache.catalina.core.StandardWrapper.load(StandardWrapper.java:993)
在 org.apache.catalina.core.StandardContext.loadOnStartup(StandardContext.java:4149)
在 org.apache.catalina.core.StandardContext.start(StandardContext.java:4458)
在 org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791)
在 org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771)
在 org.apache.catalina.core.StandardHost.addChild(StandardHost.java:526)
在 org.apache.catalina.startup.HostConfig.deployDescriptor(HostConfig.java:630)
在 org.apache.catalina.startup.HostConfig.deployDescriptors(HostConfig.java:556)
在 org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:491)
在 org.apache.catalina.startup.HostConfig.start(HostConfig.java:1206)
在 org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:314)
在 org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
在 org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)
在 org.apache.catalina.core.StandardHost.start(StandardHost.java:722)
在 org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
在 org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443)
在 org.apache.catalina.core.StandardService.start(StandardService.java:516)
在 org.apache.catalina.core.StandardServer.start(StandardServer.java:710)
在 org.apache.catalina.startup.Catalina.start(Catalina.java:583)
在 sun.reflect.NativeMethodAccessorImpl.invoke0( native 方法)
在 sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
在 sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
在 java.lang.reflect.Method.invoke(Method.java:597)
在 org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:288)
在 org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413)

这让我觉得我的 struts-config.xml 有问题,但这在大约 2 年内根本没有改变并且一直运行良好。

有什么想法吗?

最佳答案

您的 struts-config.xml 文件引用位于 jakarta.apache.org 站点的远程 DTD。虽然位置有效,但解析器尝试下载和使用 DTD 可能会失败,这可能是由于代理过滤传出流量并返回 DTD 的无效内容。

您可以下载 DTD 并将其托管在您自己的环境中,并让 struts-config.xml 文件使用这个新位置,如下所示:

<!DOCTYPE struts-config PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 1.2//EN" "http://example-org.com/struts-config_1_2.dtd">

其中 example-org.com 指的是本地网络服务器。

您也可以使用文件 URI 来引用本地目录上托管的 DTD:

<!DOCTYPE struts-config PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 1.2//EN" "file:///tmp/struts-config_1_2.dtd">

当您将 struts-config_1_2.dtd 文件放在 Tomcat 主机的 /tmp 目录中时,它会起作用;您需要确保 Tomcat 可以读取此文件。

关于java - 启动 Tomcat 时出错 - 外部参数实体 "%[dtd];"“在标记后有字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7711531/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com