java web app-为servlet上下文侦听器向web.xml添加内容后无法看到jsp文件

Posted

技术标签:

【中文标题】java web app-为servlet上下文侦听器向web.xml添加内容后无法看到jsp文件【英文标题】:java web app- unable to see jsp file after adding content to web.xml for servlet context listener 【发布时间】:2012-08-04 22:03:54 【问题描述】:

我已将以下内容添加到我的 web.xml 中以用于 servlet 上下文侦听器---

 <listener>
 <listener-class>
 com.anyaservices.log4j.ApplicationServletContextListener
 </listener-class>
 </listener>

我在“welcome-file-list”结束后立即添加了这个

welcome-file-list 节点的最后一行如下--

 </welcome-file-list>

现在,我对 servlet 进行了一些更改,以便它可以使用上下文侦听器...除了 servlet 之外,还有一个“Hello.jsp”文件,它只显示一条欢迎消息。

我没有对 JSP 文件进行任何更改。但是,在我为 servlet 上下文侦听器更改代码后,当我尝试转到 Hello.jsp 时,Tomcat 中出现错误=请求的资源不可用。

我在这里做错了什么?为什么现在没有显示 JSP 文件?

编辑——我已经在下面发布了我的 web.xml 的全部内容——

  <?xml version="1.0" encoding="UTF-8"?>
  <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
    <display-name>Test Web Application</display-name>
    <welcome-file-list>
      <welcome-file>index.html</welcome-file>
      <welcome-file>index.htm</welcome-file>
      <welcome-file>index.jsp</welcome-file>
      <welcome-file>default.html</welcome-file>
      <welcome-file>default.htm</welcome-file>
      <welcome-file>Hello.jsp</welcome-file>
    </welcome-file-list>
    <listener>
    <listener-class>
     com.test.log4j.ApplicationServletContextListener
    </listener-class>
  </listener>
    <servlet>
      <description>Used to run a single crawl job</description>
      <display-name>runsinglecrawljob</display-name>
      <servlet-name>runsinglecrawljob</servlet-name>
      <servlet-class>com.test.runsinglecrawljob</servlet-class>
    </servlet>
    <servlet-mapping>
      <servlet-name>runsinglecrawljob</servlet-name>
      <url-pattern>/runsinglecrawljob</url-pattern>
    </servlet-mapping>
    <servlet>
      <description>Home page</description>
      <display-name>home</display-name>
      <servlet-name>home</servlet-name>
      <servlet-class>home</servlet-class>
    </servlet>
    <servlet-mapping>
      <servlet-name>home</servlet-name>
      <url-pattern>/home</url-pattern>
    </servlet-mapping>
    <servlet>
      <description>Run a single crawl job after asking users for parameters of that       job</description>
      <display-name>runsinglejob</display-name>
      <servlet-name>runsinglejob</servlet-name>
      <servlet-class>com.test.runsinglecrawljob</servlet-class>
    </servlet>
    <servlet-mapping>
      <servlet-name>runsinglejob</servlet-name>
      <url-pattern>/runsinglejob</url-pattern>
    </servlet-mapping>

  </web-app>

我尝试访问的 URL 是 http://localhost:8080/test_web_app/Hello.jsp

【问题讨论】:

能否请您发布整个 web.xml 和您正在访问的 URL? @EugenePavlovsky 请查看我的编辑... 【参考方案1】:

Tomcat 通过 org.apache.jasper.servlet.JspServlet 处理 JSP 文件。也许您的侦听器类以某种方式干扰了 JspServlet 的操作。无需在欢迎文件列表中列出所有这些文件。战争中的任何 jsp 文件都应该可用(但不应放在 WEB-INF 或 META-INF 文件夹中。)

我认为您应该检查您的 log4j 配置。您是否使用 WEB-INF/classes 中的 log4j.properties 文件初始化 log4j?

【讨论】:

以上是关于java web app-为servlet上下文侦听器向web.xml添加内容后无法看到jsp文件的主要内容,如果未能解决你的问题,请参考以下文章

上下文 —— ServletConfigServletContext

单元测试 Spring MVC web-app:无法自动装配字段:私有 javax.servlet.ServletContext

java 学习之路 - web监听器

Java Web学习笔记8

servlet入门

Java Web容器的启动过程