java - 需要帮助理解 Tomcat servlet 中的异常

标签 java tomcat servlets servlet-filters

我有以下异常:

Servlet.service() for servlet indexpage threw exception java.lang.NullPointerException
at org.apache.catalina.servlets.DefaultServlet.serveResource(DefaultServlet.java:675)
at org.apache.catalina.servlets.DefaultServlet.doHead(DefaultServlet.java:351)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:634)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at planplatform.cors.CorsFilter.doFilter(CorsFilter.java:61)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298)
at org.apache.jk.server.JkCoyoteHandler.invoke(JkCoyoteHandler.java:190)
at org.apache.jk.common.HandlerRequest.invoke(HandlerRequest.java:291)
at org.apache.jk.common.ChannelSocket.invoke(ChannelSocket.java:769)
at org.apache.jk.common.ChannelSocket.processConnection(ChannelSocket.java:698)
at org.apache.jk.common.ChannelSocket$SocketConnection.runIt(ChannelSocket.java:891)
at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:690)
at java.lang.Thread.run(Unknown Source)

此异常中唯一属于我的代码是 CorsFilter:

HttpServletRequest req = (HttpServletRequest) servletRequest;
    HttpServletResponse resp = (HttpServletResponse) servletResponse;

    String origin = req.getHeader("Origin");

    boolean shouldAllowCorsOnOrigin = allowCorsOnOrigin(origin);

    if (shouldAllowCorsOnOrigin) 
    {
        resp.addHeader("Access-Control-Allow-Origin", origin);
        resp.addHeader("Access-Control-Allow-Credentials", "true");

        resp.setHeader("Allow", "GET, HEAD, POST, PUT, DELETE, TRACE, OPTIONS");

        String headers = req.getHeader("Access-Control-Request-Headers");
        String method = req.getHeader("Access-Control-Request-Method");
        resp.addHeader("Access-Control-Allow-Methods", method);
        resp.addHeader("Access-Control-Allow-Headers", headers);

        if ("options".equalsIgnoreCase(req.getMethod())) 
        {
            resp.setContentType("text/plain");

            resp.getWriter().flush();
            return;
        }
    }

    // Fix ios6 caching post requests
    if ("post".equalsIgnoreCase(req.getMethod())) {
        resp.addHeader("Cache-Control", "no-cache");
    }

    if (filterChain != null) {
        filterChain.doFilter(req, resp);
    }

shouldAllowCorsOnOrigin为false,所以代码不进入大if。

知道为什么会发生异常吗?

最佳答案

我会获取 Tomcat 的版本号并查找该版本的 DefaultServlet 的源代码。我查找了 6.0.26,但堆栈跟踪中的行号与可能引发此错误的行不一致。

DefaultServlet 中抛出错误的方法取决于从它自己的上下文或 JNDI 查找中获得的资源。在您的日志中进一步查看以“无资源”作为消息的异常。 DefaultServlet.init() 方法使用两个常量来查找资源——服务器环境是否有其中之一的资源?

关于java - 需要帮助理解 Tomcat servlet 中的异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16748125/

相关文章:

java - 客户端发送的请求在语法上不正确,multipart/form-data 和 content-length 大于 9375 字节

servlets - 生成新的 session ID

java - overridePendingTransition 不适用于适配器 (android)

java - 如何在 Web 应用程序中重新加载资源包?

java - 如何找到多维数组的值总和并替换未使用索引的值?

java - 如何在服务器端处理java请求?

linux - 在 Ubuntu 12.04 上重新安装 Apache Tomcat7

java - 如何使用ExtJs向服务器发送参数?

java - 无法使用 JSTL 打印出列表对象内容

java - 如何在我本地机器上的eclipse中运行Tomcat服务器上的web应用项目