繁体   English   中英

如何更改默认 java 方法

[英]How to change default java methods

我的项目遇到了一些问题(可能是因为 windows、防病毒软件或两者兼而有之)。

发生了什么是以下错误:

SEVERE: Exception Processing ErrorPage[errorCode=404, location=/404.jsp]
org.apache.jasper.JasperException: org.apache.jasper.JasperException: Unable to compile class for JSP
        at org.apache.jasper.servlet.JspServletWrapper.handleJspException(JspServletWrapper.java:565)
        at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:389)
        at org.apache.jasper.servlet.JspServlet._serviceJspFile(JspServlet.java:386)
        at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:40001)
        at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:330)
        at javax.servlet.http.HttpServlet.service(HttpServlet.java:742)
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
        at org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:728)
        at org.apache.catalina.core.ApplicationDispatcher.processRequest(ApplicationDispatcher.java:472)
        at org.apache.catalina.core.ApplicationDispatcher.doForward(ApplicationDispatcher.java:395)
        at org.apache.catalina.core.ApplicationDispatcher.forward(ApplicationDispatcher.java:316)
        at org.apache.catalina.core.StandardHostValve.custom(StandardHostValve.java:395)
        at org.apache.catalina.core.StandardHostValve.status(StandardHostValve.java:254)
        at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:177)
        at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:81)
        at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)
        at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:650)
        at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342)
        at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:800)
        at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
        at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:800)
        at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1471)
        at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
        at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
        at java.lang.Thread.run(Thread.java:748)
Caused by: org.apache.jasper.JasperException: Unable to compile class for JSP
        at org.apache.jasper.JspCompilationContext.compile(JspCompilationContext.java:610)
        at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:368)
        ... 26 more
Caused by: java.io.IOException: classFile.delete() failed
        at org.apache.jasper.compiler.SmapUtil$SDEInstaller.install(SmapUtil.java:204)
        at org.apache.jasper.compiler.SmapUtil.installSmap(SmapUtil.java:166)
        at org.apache.jasper.compiler.JDTCompiler.generateClass(JDTCompiler.java:510)
        at org.apache.jasper.compiler.Compiler.__compile(Compiler.java:379)
        at org.apache.jasper.compiler.Compiler.compile(Compiler.java:41002)
        at org.apache.jasper.compiler.Compiler.compile(Compiler.java:351)
        at org.apache.jasper.compiler.Compiler.compile(Compiler.java:335)
        at org.apache.jasper.JspCompilationContext.compile(JspCompilationContext.java:595)
        ... 27 more

看起来 classFile.delete() 试图删除的文件正在使用中。

我们无法在防病毒软件中添加例外......

我发现一个 2006 年的帖子说“我的解决方法是修改 SmapUtil class。如果第一次尝试重命名失败,它会等待 50 毫秒然后重试(根据需要循环)。到目前为止,它总是在 50 毫秒后的第二次尝试中工作延迟。”

我的问题是,SmapUtil class 的位置以及如何编辑删除(和重命名)方法?

我在任何地方都找不到此信息

谢谢

确保您已将 Tomcat 和 Jasper 配置为在生产中运行。

要解决您的特定问题,您可以将 Jasper 选项suppressSmap设置为true预编译您的 JSP 文件,或两者兼而有之。

SMAP 为 Jasper 提供 JSR-045 支持; 它创建从生成的字节码到源 JSP 文件的映射,以帮助调试。

有关 Jasper 配置的信息,请参阅此页面

我能够通过更改 Tomcat 方法(删除和重命名)来“修复”它

看起来它试图删除/重命名的任何文件都被另一个进程(可能是防病毒)使用

所以我从 Tomcat 的 Github 克隆了源代码,更改了 class 和瞧,它现在可以工作了。

该方法类似于:

    if ( !classPath.delete(..) )
      throw Exception...

然后我改变了类似的东西:

    while ( !classPath.delete(..) && count < 10){
      Thread.wait(50);
      count++
    }

    if (count == 10) 
         Throw Exception

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM