【问题标题】:JSP Form Not Connecting with Servlet 404-ErrorJSP 表单未与 Servlet 404 连接 - 错误
【发布时间】:2014-06-04 17:32:09
【问题描述】:

我在连接我的 servlet 时遇到了一点问题,因此我可以将一些数据传递给 mysql 数据库。我在这里阅读了很多主题,但对其他成员的建议没有运气。

我有一个名为“insertData.jsp”的 jsp 页面 在该页面上有一个表单,其中操作指向一个名为“UpdateData”的 servlet。当我在网页上单击提交时,我收到一个 404 错误,指出请求的资源不可用。我还更新了我的 web xml 文件以尝试指向正确的方向。

这是我的文件夹设置: UpdateData.java 位于源包文件夹的控制器包中。项目名称为“RukertContainerTracker”。

这是我的jsp页面:

<%@taglib prefix="sql" uri="http://java.sun.com/jsp/jstl/sql"%>
<%@page import="java.sql.ResultSet"%>
<%@page import="java.sql.Statement"%>
<%@page import="java.sql.DriverManager"%>
<%@page import="java.sql.Connection"%>
<%@page contentType="text/html" pageEncoding="UTF-8"%>

<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>Insert Data</title>
    </head>
    <body>
        <h1>Insert Data Into Container Records</h1>

        <H1>The Rukert Terminals Container Tracker </H1>

        <form name="Insert Record" action="/UpdateData" method="Post">

            Container Number: <input type="text" name="containerNumber"> <br /> 
            Full Out: <input type="date" name="fullOut" /> <br/>
            Empty In: <input type="date" name="emptyIn" /> <br/>
            Empty Out <input type="date" name="emptyOut" /> <br/>
            Full In: <input type="date" name="fullIn" /> <br/>
            Comments: <input type="text" name="comments" /> <br/>           
            <input type="submit" value="Submit" />        

        </form>


               <div>
            <a href="javascript:history.back();">
            <span class="categoryLabelText">HOME</span>
        </a>

        </div>


    </body>
</html>

我的小服务程序:

    package controller;

import java.io.IOException; 
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import javax.servlet.ServletException; 
import javax.servlet.http.HttpServlet; 
import javax.servlet.http.HttpServletRequest; 
import javax.servlet.http.HttpServletResponse; 

public class UpdateData extends HttpServlet {    
    protected void processRequest(HttpServletRequest request, HttpServletResponse     response) 
            throws ServletException, IOException, SQLException { 

       //Get container data from the JSP page 

        String container=request.getParameter("containerNumber"); 
        String fullOutDate=request.getParameter("fullOut"); 
        String emptyInDate=request.getParameter("emptyIn");
        String emptyOutDate=request.getParameter("emptyOut");
        String fullInDate=request.getParameter("fullIn");
        String comments=request.getParameter("comments");

        //Print the above got values in console 

        System.out.println("The username is" +container); 
        System.out.println("\nand the password is" +fullOutDate);

        String connectionparams="jdbc:mysql://localhost:3306/rukerttracker";
        String db="rukerttracker";

        String uname="root";
        String psword="Colorado1982";

        Connection connection=null;

        ResultSet rs; 
        try { 

          // Loading the available driver for a Database communication 

            Class.forName("com.mysql.jdbc.Driver"); 

//Creating a connection to the required database 

            connection = DriverManager.getConnection 
             (connectionparams, uname, psword); 

       //Add the data into the database 

            String sql = "insert into containerinventory values (?,?,?,?,?,?)";
            try (PreparedStatement prep = connection.prepareStatement(sql)) {
                prep.setString(1, container);
                prep.setString(2, fullOutDate);
                prep.setString(3, emptyInDate);
                prep.setString(4, emptyOutDate);
                prep.setString(5, fullInDate);
                prep.setString(6, comments);

                prep.executeUpdate();
            } 

           }catch(Exception E){

               System.out.println("The error is=="+E.getMessage()); 


           }


finally{
            connection.close();
        }


    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {

        String userPath = request.getServletPath();

        // if category page is requested
        if (userPath.equals("/insertData")) {
            // TODO: Implement category request


            // use RequestDispatcher to forward request internally
        String url = "/WEB-INF/view" + userPath + ".jsp";

        try {
            request.getRequestDispatcher(url).forward(request, response);
        } catch (Exception ex) {
            ex.printStackTrace();
        }
    }
    }
}

最后是我的 web.xml 页面:

 <servlet>
        <servlet-name>ControllerServlet</servlet-name>
        <servlet-class>controller.ControllerServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>ControllerServlet</servlet-name>
        <url-pattern>/chooseLanguage</url-pattern>
        <url-pattern>/viewTracker</url-pattern>
        <url-pattern>/editTracker</url-pattern>
        <url-pattern>/addToCart</url-pattern>
        <url-pattern>/viewCompany</url-pattern>
        <url-pattern>/category</url-pattern>
        <url-pattern>/updateCart</url-pattern>
        <url-pattern>/purchase</url-pattern>
        <url-pattern>/viewCart</url-pattern>
        <url-pattern>/checkout</url-pattern>

    </servlet-mapping>
    <servlet>
        <servlet-name>UpdateData</servlet-name>
        <servlet-class>controller.UpdateData</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>UpdateData</servlet-name>
        <url-pattern>/insertData</url-pattern>
    </servlet-mapping>

我有两个 servlet,我不知道这是否重要,但我无法让应用程序在控制器 servlet 中工作,所以我创建了更新数据 servlet。

任何关于为什么我不断收到此 404 错误的帮助将不胜感激。感谢您抽出宝贵时间查看此内容。

【问题讨论】:

    标签: java mysql jsp servlets netbeans


    【解决方案1】:

    我认为您正在使用 POST 方法,而您的 servlet 没有 post 方法。请检查一下。 protected void doPost(HttpServletRequest 请求,HttpServletResponse 响应) 抛出 ServletException、IOException {...} 不可用。

    【讨论】:

    • Subhash,感谢您的洞察力。我应该只是将一个空的 POST 方法添加到 servlet,还是将我的所有代码从 servlet 中的 processRequest 调用放到新创建的 POST 方法中?您可以分享的任何其他想法都会很棒。基本上,正如您可能看到的那样,我正在尝试做的是将数据从表单传递到 servlet 到 mysql 数据库(我正在尝试输入数据库)。
    • 从 doPost 调用您的 processRequest 方法,如 void processRequest(request,response)
    • Subhash,你真的很有帮助。只是我有点困惑,你介意给我一个我应该尝试的代码的sn-p吗?从我正在阅读的内容来看,您似乎在建议我做类似的事情:受保护的无效doPost(请求,响应)......我应该在mehtod(请求,响应)中使用这些确切的词吗?对不起,如果我很痛苦,我真的很想学习这些东西。再次感谢您的时间和耐心。
    • 另外,我应该在哪里添加新代码?到我的 servlet 的底部,还是顶部?有关系吗?再次感谢。
    猜你喜欢
    • 2018-10-30
    • 1970-01-01
    • 2014-02-01
    • 2012-05-23
    • 1970-01-01
    • 2011-03-21
    • 2018-02-01
    • 1970-01-01
    • 2017-12-03
    相关资源
    最近更新 更多