tongweb部署报这个错误:
com.tongweb.catalina.LifecycleException: Failed to start component [StandardEngine[TONGWEB].StandardHost[server].StandardContext[frmis]]
at com.tongweb.catalina.util.LifecycleBase.start(LifecycleBase.java:167)
at com.tongweb.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:724)
at com.tongweb.catalina.core.ContainerBase.addChild(ContainerBase.java:700)
at com.tongweb.catalina.core.StandardHost.addChild(StandardHost.java:734)
at com.tongweb.catalina.core.ThanosStandardHost.addChild(ThanosStandardHost.java:542)
at com.tongweb.web.thanos.startup.ThanosHostConfig.deployWar(ThanosHostConfig.java:225)
at com.tongweb.tw.thanos.ThanosTomcatWebAppBuilder.fireTomcatProcess(ThanosTomcatWebAppBuilder.java:415)
at com.tongweb.tw.thanos.ThanosTomcatWebAppBuilder.deployApplication(ThanosTomcatWebAppBuilder.java:362)
at com.tongweb.deploy.TongWebDeployer.deploy0(TongWebDeployer.java:200)
at com.tongweb.deploy.TongWebDeployer.deploy(TongWebDeployer.java:160)
at com.tongweb.deploy.commands.DeployCommand.deploy(DeployCommand.java:269)
at com.tongweb.console.deployer.service.DeployerService.deploy(DeployerService.java:495)
at com.tongweb.console.deployer.controller.DeployerController.deploy(DeployerController.java:314)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:601)
at org.jboss.resteasy.core.MethodInjectorImpl.invoke(MethodInjectorImpl.java:137)
at org.jboss.resteasy.core.ResourceMethodInvoker.invokeOnTarget(ResourceMethodInvoker.java:296)
at org.jboss.resteasy.core.ResourceMethodInvoker.invoke(ResourceMethodInvoker.java:250)
at org.jboss.resteasy.core.ResourceMethodInvoker.invoke(ResourceMethodInvoker.java:237)
at org.jboss.resteasy.springmvc.ResteasyHandlerAdapter.createModelAndView(ResteasyHandlerAdapter.java:96)
at org.jboss.resteasy.springmvc.ResteasyHandlerAdapter.handle(ResteasyHandlerAdapter.java:82)
at org.jboss.resteasy.springmvc.ResteasyHandlerAdapter.handle(ResteasyHandlerAdapter.java:26)
at org.jboss.resteasy.springmvc.ResteasyWebHandlerTemplate.handle(ResteasyWebHandlerTemplate.java:39)
at org.jboss.resteasy.springmvc.ResteasyHandlerAdapter.handle(ResteasyHandlerAdapter.java:47)
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:933)
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:867)
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:953)
at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:855)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:648)
at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:829)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:729)
at com.tongweb.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:230)
at com.tongweb.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)
at com.tongweb.web.websocket.server.WsFilter.doFilter(WsFilter.java:52)
at com.tongweb.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)
at com.tongweb.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)
at com.tongweb.tongejb.server.httpd.EEFilter.doFilter(EEFilter.java:65)
at com.tongweb.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)
at com.tongweb.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)
at com.tongweb.console.util.SpringI18nFilter.doFilter(SpringI18nFilter.java:46)
at com.tongweb.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)
at com.tongweb.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)
at com.tongweb.console.commons.LoginFilter.doFilter(LoginFilter.java:50)
at com.tongweb.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)
at com.tongweb.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)
at com.tongweb.console.commons.ConsoleFilter.doFilter(ConsoleFilter.java:62)
at com.tongweb.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)
at com.tongweb.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)
at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:106)
at com.tongweb.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)
at com.tongweb.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)
at com.tongweb.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:198)
at com.tongweb.catalina.core.StandardContextValve.invoke(StandardContextValve.java:108)
at com.tongweb.catalina.core.ThanosStandardContextValve.invoke(ThanosStandardContextValve.java:26)
at com.tongweb.tomee.catalina.OpenEJBValve.invoke(OpenEJBValve.java:44)
at com.tongweb.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:589)
at com.tongweb.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140)
at com.tongweb.tomee.catalina.OpenEJBSecurityListener$RequestCapturer.invoke(OpenEJBSecurityListener.java:97)
at com.tongweb.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:79)
at com.tongweb.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)
at com.tongweb.catalina.core.ThanosStandardEngineValve.invoke(ThanosStandardEngineValve.java:71)
at com.tongweb.catalina.realm.RealmValve.invoke(RealmValve.java:30)
at com.tongweb.catalina.connector.ThanosCoyoteAdaptor.service(ThanosCoyoteAdaptor.java:407)
at com.tongweb.coyote.http11.Http11Processor.service(Http11Processor.java:774)
at com.tongweb.coyote.http11.ThanosHttp11Processor.service(ThanosHttp11Processor.java:19)
at com.tongweb.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
at com.tongweb.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:803)
at com.tongweb.web.util.net.Nio2Endpoint$SocketProcessor.doRun(Nio2Endpoint.java:1609)
at com.tongweb.web.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
at com.tongweb.web.util.net.AbstractEndpoint.processSocket(AbstractEndpoint.java:832)
at com.tongweb.web.util.net.Nio2Endpoint$Nio2SocketWrapper$4.completed(Nio2Endpoint.java:639)
at com.tongweb.web.util.net.Nio2Endpoint$Nio2SocketWrapper$4.completed(Nio2Endpoint.java:617)
at sun.nio.ch.Invoker.invokeUnchecked(Invoker.java:126)
at sun.nio.ch.Invoker$2.run(Invoker.java:206)
at sun.nio.ch.AsynchronousChannelGroupImpl$1.run(AsynchronousChannelGroupImpl.java:112)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
at com.tongweb.web.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Thread.java:722)
Caused by: com.tongweb.tomee.catalina.TomEERuntimeException: com.tongweb.tongejb.OpenEJBException: Unable to create annotation scanner for web module frmis: MALFORMED
at com.tongweb.tomee.catalina.TomcatWebAppBuilder.loadApplication(TomcatWebAppBuilder.java:2306)
at com.tongweb.tw.thanos.ThanosTomcatWebAppBuilder.startInternal(ThanosTomcatWebAppBuilder.java:972)
at com.tongweb.tomee.catalina.TomcatWebAppBuilder.configureStart(TomcatWebAppBuilder.java:1131)
at com.tongweb.tomee.catalina.GlobalListenerSupport.lifecycleEvent(GlobalListenerSupport.java:133)
at com.tongweb.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:94)
at com.tongweb.catalina.core.StandardContext.startInternal(StandardContext.java:5091)
at com.tongweb.catalina.core.ThanosStandardContext.startInternal(ThanosStandardContext.java:159)
at com.tongweb.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
... 81 more
Caused by: com.tongweb.tongejb.OpenEJBException: Unable to create annotation scanner for web module frmis: MALFORMED
at com.tongweb.tongejb.config.DeploymentLoader.addWebModule(DeploymentLoader.java:909)
at com.tongweb.tongejb.config.DeploymentLoader.load(DeploymentLoader.java:232)
at com.tongweb.tomee.catalina.TomcatWebAppBuilder.loadApplication(TomcatWebAppBuilder.java:2304)
... 88 more
Caused by: java.lang.IllegalArgumentException: MALFORMED
at java.util.zip.ZipCoder.toString(ZipCoder.java:58)
at java.util.zip.ZipFile.getZipEntry(ZipFile.java:529)
at java.util.zip.ZipFile.access$900(ZipFile.java:56)
at java.util.zip.ZipFile$1.nextElement(ZipFile.java:511)
at java.util.zip.ZipFile$1.nextElement(ZipFile.java:481)
at java.util.jar.JarFile$1.nextElement(JarFile.java:243)
at java.util.jar.JarFile$1.nextElement(JarFile.java:238)
at com.tongweb.xbean.finder.archive.JarArchive$JarIterator.advance(JarArchive.java:103)
at com.tongweb.xbean.finder.archive.JarArchive$JarIterator.hasNext(JarArchive.java:124)
at com.tongweb.xbean.finder.archive.FilteredArchive$FilteredIterator.hasNext(FilteredArchive.java:63)
at com.tongweb.xbean.finder.archive.CompositeArchive$CompositeIterator.hasNext(CompositeArchive.java:85)
at com.tongweb.xbean.finder.AnnotationFinder.<init>(AnnotationFinder.java:145)
at com.tongweb.xbean.finder.AnnotationFinder.<init>(AnnotationFinder.java:161)
at com.tongweb.tongejb.config.FinderFactory$OpenEJBAnnotationFinder.<init>(FinderFactory.java:546)
at com.tongweb.tongejb.config.FinderFactory.newFinder(FinderFactory.java:267)
at com.tongweb.tongejb.config.FinderFactory.create(FinderFactory.java:80)
at com.tongweb.tongejb.config.FinderFactory.createFinder(FinderFactory.java:69)
at com.tongweb.tongejb.config.DeploymentLoader.addWebModule(DeploymentLoader.java:901)
... 90 more
原因就是部署应用依赖第三方jar包中文命名文件,或者jar报中有中文命名的class文件,比如备份的class文件:
但是怎么找到这个问题jar包呢,可以通过如下程序快速定位是哪个jar包的哪个目录下有问题
String key = "AnnotationFinder";
String path = "D:\\Oracle\\Middleware\\user_projects\\domains\\fasp_domain7002\\ifmis_fasp_2.3.2.42\\WEB-INF\\lib";
path = "D:\\frmis\\WEB-INF\\lib";
File dir = new File(path);
if (dir.isDirectory()) {
File[] files = dir.listFiles();
for (File file : files) {
if (file.getName().endsWith("jar")) {
try {
// System.out.println(file.getName());
JarFile jarFile = new JarFile(file.getAbsolutePath());
Enumeration<JarEntry> entries = jarFile.entries();
System.out.println(jarFile.getName());
while (entries.hasMoreElements()) {
//System.out.println(entries.nextElement().getName());
String name = entries.nextElement().getName();
System.out.println(name);
if (name.contains(key)) {
System.out.println(name);
System.out.println(file.getName());
}
}
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
} else {
//System.out.println();
System.err.println("所选为文件!");
}