簡體   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