HTTP 404 not found(Servlet未找到)

7

我是一名学生,正在学习使用jsp和servlet构建Web应用程序。我的Web应用程序项目自一个月以来一直运行良好,但今天突然表现异常。当我提交我的jsp页面时,它无法找到我的servlet。我已经使用了servlet注解来映射请求。

以下是我的jsp代码:

<form name=registration_form action="<%=application.getContextPath() %>/Registration" method="post">  
    First Name:</td><td><input type="text" name="firstName" required/></td></tr> 
    </form>

以下是我的Servlet代码:

package servlets;
    @WebServlet("/Registration")
    public class Registration extends HttpServlet {
        private static final long serialVersionUID = 1L;
        public Registration() {
            super();
        }

        protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            // TODO Auto-generated method stub
        }

        protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            String firstName=request.getParameter("firstName"); 
            System.out.println(firstName);
        }
    }

以下是我的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_3_0.xsd" id="WebApp_ID" version="3.0">
  <display-name>Login</display-name>
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
</web-app>

以下是我的项目层次结构:

在这里输入图片描述

以下是错误信息:

HTTP Status 404 - /Login/Registration
type Status report

message /Login/Registration

description The requested resource is not available.

Apache Tomcat/7.0.47 

以下是我的控制台日志:

Mar 11, 2014 11:30:33 AM org.apache.catalina.core.AprLifecycleListener init
INFO: The APR based Apache Tomcat Native library which allows optimal performance in production environments was not found on the java.library.path: C:\Program Files (x86)\Java\jre7\bin;C:\windows\Sun\Java\bin;C:\windows\system32;C:\windows;C:/Program Files (x86)/Java/jdk1.6.0_17/bin/../jre/bin/client;C:/Program Files (x86)/Java/jdk1.6.0_17/bin/../jre/bin;C:/Program Files (x86)/Java/jdk1.6.0_17/bin/../jre/lib/i386;C:\Program Files (x86)\PC Connectivity Solution\;C:\Program Files (x86)\Java\jdk1.6.0_17\bin;C:\Program Files\Common Files\Microsoft Shared\Windows Live;C:\Program Files (x86)\Common Files\Microsoft Shared\Windows Live;C:\windows\system32;C:\windows;C:\windows\System32\Wbem;C:\windows\System32\WindowsPowerShell\v1.0\;C:\Program Files\Intel\WiFi\bin\;C:\Program Files\Common Files\Intel\WirelessCommon\;c:\Program Files (x86)\Common Files\Roxio Shared\DLLShared\;c:\Program Files (x86)\Common Files\Roxio Shared\OEM\DLLShared\;c:\Program Files (x86)\Common Files\Roxio Shared\OEM\DLLShared\;c:\Program Files (x86)\Common Files\Roxio Shared\OEM\12.0\DLLShared\;c:\Program Files (x86)\Roxio\OEM\AudioCore\;C:\Program Files (x86)\Windows Live\Shared;C:\Program Files (x86)\Microsoft SQL Server\90\Tools\binn\;C:\Program Files (x86)\Android\android-sdk;C:\Program Files (x86)\Java\jdk1.6.0_17\bin;C:\Program Files (x86)\MySQL\MySQL Utilities 1.3.4\;C:\Program Files (x86)\Intel\OpenCL SDK\2.0\bin\x86;C:\Program Files (x86)\Intel\OpenCL SDK\2.0\bin\x64;D:\mongodb\bin;D:\development tools\apache-maven-3.1.1-bin\apache-maven-3.1.1\bin;C:\Program Files (x86)\Google\google_appengine\;D:\development tools\eclipse;;.
Mar 11, 2014 11:30:33 AM org.apache.tomcat.util.digester.SetPropertiesRule begin
WARNING: [SetPropertiesRule]{Server/Service/Engine/Host/Context} Setting property 'source' to 'org.eclipse.jst.jee.server:Login' did not find a matching property.
Mar 11, 2014 11:30:34 AM org.apache.coyote.AbstractProtocol init
INFO: Initializing ProtocolHandler ["http-bio-8080"]
Mar 11, 2014 11:30:34 AM org.apache.coyote.AbstractProtocol init
INFO: Initializing ProtocolHandler ["ajp-bio-8009"]
Mar 11, 2014 11:30:34 AM org.apache.catalina.startup.Catalina load
INFO: Initialization processed in 1071 ms
Mar 11, 2014 11:30:34 AM org.apache.catalina.core.StandardService startInternal
INFO: Starting service Catalina
Mar 11, 2014 11:30:34 AM org.apache.catalina.core.StandardEngine startInternal
INFO: Starting Servlet Engine: Apache Tomcat/7.0.47
Mar 11, 2014 11:30:35 AM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["http-bio-8080"]
Mar 11, 2014 11:30:35 AM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["ajp-bio-8009"]
Mar 11, 2014 11:30:35 AM org.apache.catalina.startup.Catalina start
INFO: Server startup in 1463 ms

问题在于它找不到路径,尝试将其更改为 action="./Registration" - Santhosh
1
@sankrish 它找到了正确的路径,即“http://localhost:8080/Login/Registration”,但仍然给我错误。这个应用程序突然开始出错,之前它一直正常工作。 - Saumyaraj
你的Servlet位于servlets包中,但它指向源包的路径。 - Santhosh
3个回答

14

我也曾遇到过这个问题。每当我们删除一个Tomcat服务器并在没有构建类路径和清理构建项目的情况下在新服务器上运行项目时,我们会遇到此类异常。

因此,请构建您项目的类路径。前往您项目的属性,然后选择=>Java Build Path => Order and Export. 选中所有类路径。


2
清理所有项目也可以。 - Dmitry
对我来说,这是我的第一个项目,我遇到了同样的问题。 - Chedi Bechikh

2

你的 Servlet 路径是 /Registration,但请求指向 /Login/Registration

你需要更新表单的 action 属性。

action="${pageContext.request.contextPath}/Registration"

或者
action="/Registration"

在操作中,我已经指定了相同的 application.getContextPath() %>/Registration。 - Saumyaraj
验证您的应用程序.getContextPath()是否解析为http://localhost:8080/AppName/或http://localhost:8080/AppName/Login/。 - shazin

2

在您的JSP动作页面中使用以下格式:

action="/Registration"

并且这个网页:

<servlet>
<servlet-name>Registration</servlet-name>
 <servlet-class>packagename.Registration</servlet-class>
</servlet> 
<servlet-mapping>
<servlet-name>Registration</servlet-name>
 <url-pattern>/Registration</url-pattern>
</servlet-mapping>

follow this


不需要,因为我已经使用了Servlet注解。 - Saumyaraj

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接