struts Caused by: no protocol dtd - Class: java.net.URL

简介:

情景:

项目使用了struts2框架,部署到tomcat中,而tomcat所在机器没有联网(处于公司安全方面的原因),所以启动tomcat时,报错:

tomcat Unable to load configuration. - Class: Java.net.SocketInputStream

因为struts配置文件如下:

Xml代码   收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <!DOCTYPE struts PUBLIC  
  3.         "-//Apache Software Foundation/DTD Struts Configuration 2.1.7//EN"  
  4.         "http://struts.apache.org/dtds/struts-2.3.dtd">  

如上所示,它会 去http://struts.apache.org/dtds/struts-2.3.dtd下载dtd文件,但是没有联网,所以就报上述错误(标红的)了。

 

为了解决这个问题,就使用了本地的dtd文件,范例:

Xml代码   收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <!DOCTYPE struts PUBLIC  
  3.         "-//Apache Software Foundation/DTD Struts Configuration 2.1.7//EN"  
  4.         "./com/tdr/mbs/endpoint/dtd/struts-2.3.dtd">  

 

后来项目部署到其他tomcat时,报错:

Caused by: no protocol dtd - Class: java.net.URL

详细报错信息:

 

Java代码   收藏代码
  1. Unable to load configuration. - Class: java.net.URL  
  2. File: URL.java  
  3. Method: <init>  
  4. Line: 567 - java/net/URL.java:567:-1  
  5.     at com.opensymphony.xwork2.config.ConfigurationManager.getConfiguration(ConfigurationManager.java:69)  
  6.     at org.apache.struts2.dispatcher.Dispatcher.init_PreloadConfiguration(Dispatcher.java:390)  
  7.     at org.apache.struts2.dispatcher.Dispatcher.init(Dispatcher.java:437)  
  8.     at org.apache.struts2.dispatcher.ng.InitOperations.initDispatcher(InitOperations.java:74)  
  9.     at org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.init(StrutsPrepareAndExecuteFilter.java:51)  
  10.     at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:295)  
  11.     at org.apache.catalina.core.ApplicationFilterConfig.setFilterDef(ApplicationFilterConfig.java:422)  
  12.     at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:115)  
  13.     at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:3838)  
  14.     at org.apache.catalina.core.StandardContext.start(StandardContext.java:4488)  
  15.     at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)  
  16.     at org.apache.catalina.core.StandardHost.start(StandardHost.java:722)  
  17.     at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)  
  18.     at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443)  
  19.     at org.apache.catalina.core.StandardService.start(StandardService.java:516)  
  20.     at org.apache.catalina.core.StandardServer.start(StandardServer.java:710)  
  21.     at org.apache.catalina.startup.Catalina.start(Catalina.java:593)  
  22.     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)  
  23.     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)  
  24.     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)  
  25.     at java.lang.reflect.Method.invoke(Method.java:597)  
  26.     at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289)  
  27.     at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)  
  28. Caused by: Unable to load file:/D:/个人资料/eclipse/workspace/.metadata/.plugins/org.eclipse.wst.server.core/tmp0/wtpwebapps/endpoint/WEB-INF/classes/struts.xml - Class: java.net.URL  
  29. File: URL.java  
  30. Method: <init>  
  31. Line: 567 - java/net/URL.java:567:-1  
  32.     at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.loadConfigurationFiles(XmlConfigurationProvider.java:954)  
  33.     at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.loadDocuments(XmlConfigurationProvider.java:163)  
  34.     at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.init(XmlConfigurationProvider.java:130)  
  35.     at com.opensymphony.xwork2.config.impl.DefaultConfiguration.reloadContainer(DefaultConfiguration.java:209)  
  36.     at com.opensymphony.xwork2.config.ConfigurationManager.getConfiguration(ConfigurationManager.java:66)  
  37.     ... 22 more  
  38. Caused by: no protocol: ./com/a//endpoint/dtd/struts-2.3.dtd - Class: java.net.URL  
  39. File: URL.java  
  40. Method: <init>  
  41. Line: 567 - java/net/URL.java:567:-1  
  42.     at com.opensymphony.xwork2.util.DomHelper.parse(DomHelper.java:115)  
  43.     at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.loadConfigurationFiles(XmlConfigurationProvider.java:949)  
  44.     ... 26 more  
  45. Caused by: java.net.MalformedURLException: no protocol: ./com/a//endpoint/dtd/struts-2.3.dtd  
  46.     at java.net.URL.<init>(URL.java:567)  
  47.     at java.net.URL.<init>(URL.java:464)  
  48.     at java.net.URL.<init>(URL.java:413)  
  49.     at org.apache.xerces.impl.XMLEntityManager.setupCurrentEntity(Unknown Source)  
  50.     at org.apache.xerces.impl.XMLEntityManager.startEntity(Unknown Source)  
  51.     at org.apache.xerces.impl.XMLEntityManager.startDTDEntity(Unknown Source)  
  52.     at org.apache.xerces.impl.XMLDTDScannerImpl.setInputSource(Unknown Source)  
  53.     at org.apache.xerces.impl.XMLDocumentScannerImpl$DTDDispatcher.dispatch(Unknown Source)  
  54.     at org.apache.xerces.impl.XMLDocumentFragmentScannerImpl.scanDocument(Unknown Source)  
  55.     at org.apache.xerces.parsers.XML11Configuration.parse(Unknown Source)  
  56.     at org.apache.xerces.parsers.XML11Configuration.parse(Unknown Source)  
  57.     at org.apache.xerces.parsers.XMLParser.parse(Unknown Source)  
  58.     at org.apache.xerces.parsers.AbstractSAXParser.parse(Unknown Source)  
  59.     at javax.xml.parsers.SAXParser.parse(SAXParser.java:395)  
  60.     at com.opensymphony.xwork2.util.DomHelper.parse(DomHelper.java:113)  
  61.     ... 27 more  

 

上网查了半天,发现这是tomcat的一个bug。

出现的场景:

 

<!--[if !supportLists]-->(1)   <!--[endif]-->tomcat 的安装目录中有中文字符;

struts.xml中没有使用网络上的dtd文件,而是使用的本地的dtd文件

 

问题原因tomcat 安装目录中有中文字符。

 

解决方法:tomcat的安装目录拷贝到无中文字符的路径中。

 

 后记:后来我使用eclipse运行项目,也报相同的错误,因为我eclipse的工作空间(workspace)是:

D:\个人资料\eclipse\workspace

我的eclipse的工作空间的路径中包含中文字符。

报错信息:

Caused by: Unable to load file:/D:/个人资料/eclipse/workspace/.metadata/.plugins/org.eclipse.wst.server.core/tmp0/wtpwebapps/endpoint/WEB-INF/classes/struts.xml - Class: java.net.URL

File: URL.java

Method: <init>

Line: 567 - java/net/URL.java:567:-1

 

也就是说eclipse把项目部署到了 D:/个人资料/eclipse/workspace/.metadata/ 中

解决方法:修改eclipse的工作区间(没办法了,一定要保证项目部署的路径中没有中文字符

相关文章
|
4月前
|
安全 Java
Java反射-Class对象功能概述及反射案例
Java反射-Class对象功能概述及反射案例
40 1
|
2月前
|
Dubbo Java 应用服务中间件
Serialized class org.apache.catalina.core.ApplicationPart must implement java.io.Serializable
Serialized class org.apache.catalina.core.ApplicationPart must implement java.io.Serializable
47 0
|
10天前
|
Java 应用服务中间件 Linux
Caused by: java.lang.UnsatisfiedLinkError: /root/jdk1.7.0_45/jre/lib/amd64/xawt/libmawt.so: libXrend
Caused by: java.lang.UnsatisfiedLinkError: /root/jdk1.7.0_45/jre/lib/amd64/xawt/libmawt.so: libXrend
|
16天前
|
Java 开发工具 计算机视觉
Caused by: java.lang.UnsatisfiedLinkError: Can‘t load AMD 64-bit .dll on a IA 32-bit platform【已解决】
Caused by: java.lang.UnsatisfiedLinkError: Can‘t load AMD 64-bit .dll on a IA 32-bit platform【已解决】
4 0
|
25天前
|
Java 关系型数据库 MySQL
Flink1.18.1和CDC2.4.1 本地没问题 提交任务到服务器 报错java.lang.NoClassDefFoundError: Could not initialize class io.debezium.connector.mysql.MySqlConnectorConfig
【2月更文挑战第33天】Flink1.18.1和CDC2.4.1 本地没问题 提交任务到服务器 报错java.lang.NoClassDefFoundError: Could not initialize class io.debezium.connector.mysql.MySqlConnectorConfig
43 2
|
1月前
|
监控 NoSQL Java
Spring Boot集成Redis启动失败【Caused by: java.lang.ClassNotFoundException: org.apache.commons.pool2.impl.G】
Spring Boot集成Redis启动失败【Caused by: java.lang.ClassNotFoundException: org.apache.commons.pool2.impl.G】
|
1月前
|
SpringCloudAlibaba Java Maven
【问题篇】Caused by: java.lang.NoClassDefFoundError: org/springframework/boot/context/properties/
【问题篇】Caused by: java.lang.NoClassDefFoundError: org/springframework/boot/context/properties/
13 2
|
1月前
|
开发工具
933.【开发工具】解决idea:Caused by: java.net.BindException: Add
933.【开发工具】解决idea:Caused by: java.net.BindException: Add
20 2
|
1月前
|
Java
916.【Java】javap 查看 class 文件的jdk编译版本
916.【Java】javap 查看 class 文件的jdk编译版本
45 2
|
2月前
|
Java 应用服务中间件
Caused by: java.lang.NoClassDefFoundError: org/springframework/web/context/request/async/CallablePro
Caused by: java.lang.NoClassDefFoundError: org/springframework/web/context/request/async/CallablePro 错误处理
62 0

热门文章

最新文章