Я боролся с этой проблемой в течение нескольких часов, и я не могу понять, что случилось.Много гуглил и копался в вещах, но, похоже, ничего не получалось.Я разрабатываю веб-приложение, используя eclipse, и получаю следующую ошибку при доступе к ресурсу:
HTTP Status 404 - /EditForm
type Status report
message /EditForm
description The requested resource is not available.
Немного справочной информации: я использую JSP для отправки формы, которая предназначена для использованиясервлет, написанный на Java для обработки информации.Он называется 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>
Сервлет выглядит следующим образом:
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.xml внутри моегоПапка WEB-INF:
<?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>
Структура каталога моего приложения:
--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
Я был бы очень признателен, если бы кто-то указал мне правильное направление и сказал, что яделает неправильно, что мой ресурс не может быть доступен.Спасибо.