Eclipse 404请求的资源不可用

时间:2018-05-22 09:48:26

标签: java eclipse jsp http-status-code-404

我一直在努力解决这个问题几个小时,我似乎无法弄清楚出了什么问题。做了很多谷歌搜索和挖掘的东西,但似乎没有任何工作。我正在使用eclipse开发Web应用程序,在访问资源时出现以下错误:

HTTP Status 404 - /EditForm
type Status report

message /EditForm

description The requested resource is not available.

一些背景信息:我正在使用JSP提交一个表单,该表单旨在使用用java编写的servlet来处理信息。 它被称为editProfile.jsp,这里是提交表单信息的部分。

  <form CLASS="form-horizontal" METHOD=POST ACTION="/EditForm">

    <div class="form-group">
            <label class="control-label col-sm-2"><b>New Address</b></label>
            <INPUT TYPE=TEXT PLACEHOLDER="Type new address here." NAME=address SIZE=20><BR>
    </div>
    <div class="submit_btn col-sm-2"><INPUT TYPE=SUBMIT></div> 

  <form>

Servlet如下:

 package user;

import java.io.IOException;
import java.sql.*;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.*;
import database.*;


@WebServlet("/EditForm")
public class EditForm extends HttpServlet{


/**
 * 
 */
private static final long serialVersionUID = 102831973239L;
@Override
public void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException,ServletException {

    HttpSession session = request.getSession();
    String currForm =(String) request.getParameter("currForm");
    String user = (String) session.getAttribute("username");



    if(currForm.equals("address")) {

        String sqlStmt = "UPDATE db.User SET address = '"+ currForm+"' WHERE username = '"+user+"';";
        doSQL(sqlStmt);
        response.sendRedirect("profile.jsp");

    }
    else if(currForm.equals("phone")) {

        String sqlStmt = "UPDATE db.User SET phone = '"+ currForm+"' WHERE username = '"+user+"';";
        doSQL(sqlStmt);
        response.sendRedirect("profile.jsp");

    }

    else if(currForm.equals("email")) {

        String sqlStmt = "UPDATE db.User SET email = '"+ currForm+"' WHERE username = '"+user+"';";
        doSQL(sqlStmt);
        response.sendRedirect("profile.jsp");

    }

}

public void doSQL(String stmt) {

    try {
        DatabaseOperation op = new DatabaseOperation();
        op.connect();
        op.executeQuery(stmt);

    } catch(Exception e) { e.printStackTrace(); }   

}

}

我的WEB-INF文件夹中的Web.xml是:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
 xmlns="http://xmlns.jcp.org/xml/ns/javaee" 
 xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee 
 http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" 
 version="3.1">
 <display-name>Website</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>default.jsp</welcome-file>
 </welcome-file-list>

<servlet>
  <servlet-name>EditForm</servlet-name>
  <servlet-class>user.EditForm</servlet-class>  
</servlet>

</web-app>

我的app目录结构:

   --Website
        |--Deployment Descriptor: Website
        |--JAX-WS Web Services
        |--Java Resources
        |      |--src
        |      |   |--user(package)
        |      |         |--EditForm.java
        |      |
        |      |--Libraries   
        |
        |--JavaScript Resources
        |--Referenced Libraries
        |--build
        |--WebContent
        |      |--META-INF
               |--WEB-INF
               |    |--lib
               |    |--web.xml
               |
               |--editProfile.jsp

如果有人能指出我正确的方向,并且告诉我我的错误确切地说我的资源无法访问,我将非常感激。谢谢。

2 个答案:

答案 0 :(得分:1)

Servlet容器可以托管多个Web应用程序,因此您映射的URI“/ EditForm”只会在Web服务器上部署相对于Web应用程序的上下文路径的请求,而不是“/” EditForm“绝对。 pageContext.getServletContext().getContextPath()如果要使用JSP表达式将其添加到form action值(假设您不想对其进行硬编码),则可以为您提供该路径。

如果你正在使用javax.servlet.annotation.WebServlet注释,你也不需要在部署描述符中声明Servlet,至少,除非你要在部署描述符中对它做其他事情,否则好。

答案 1 :(得分:0)

我认为你没有正确设置servlet的路径。而不是action = / EditForm尝试去动作= .. / EditForm