使用servlet在mysql中存储数据时出错

v440hwme  于 2021-06-20  发布在  Mysql
关注(0)|答案(4)|浏览(328)

我是java的一个萌芽工程师。我有一个程序,需要从servlets将员工详细信息插入mysql数据库。这是我写的程序。
员工.java

import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@SuppressWarnings("serial")
public class Employee extends HttpServlet {

    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException 
    {
        try
        {
        response.setContentType("text/html");
        PrintWriter out=response.getWriter();

        String na=request.getParameter("na");
        String add=request.getParameter("add");

            Class.forName("com.mysql.jdbc.Driver");
            Connection con=DriverManager.getConnection("jdbc:mysql://localhost:8080/servlet","root","root");
            PreparedStatement ps=con.prepareStatement("insert into employee values(?,?,?)");
            ps.setString(1,na);
            ps.setString(2,add);
            System.out.print(na+" "+add);
            int i=ps.executeUpdate();
            System.out.println(i);

        out.println("<html>");
        out.println("<body>");
        out.println("<h1>create employee Succssffuly</h1>");
        out.println("<A HREF=index.html>one more to create</A>");
        out.println("</body></html>");
        out.close();
        }
        catch(Exception e)
            {
            System.out.println(e);
            e.printStackTrace();
            }
    }

    }

登录.jsp

<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Insert title here</title>
</head>
<body>
<form action="employee" method="Post">
<table>
<tr><td>Name</td><td><input type="text" name="na"></td></tr>
<tr><td>Address</td><td><input type="text" name="add"></td></tr>
<tr><td></td><td><input type="submit" value="save"></td></tr>
</table>
</form>
</body>
</html>

网站.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" 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>Simple</display-name>
  <servlet>
  <servlet-name>simple</servlet-name>
  <servlet-class>Employee</servlet-class>
  </servlet>
  <servlet-mapping>
  <servlet-name>simple</servlet-name>
  <url-pattern>/simple</url-pattern>
  </servlet-mapping>
  <welcome-file-list>
    <welcome-file>login.jsp</welcome-file>
  </welcome-file-list>
</web-app>

当我运行这个程序时,它会询问名字和地址。保存详细信息时,会出现以下错误页

**http状态404-/simple/employee

键入状态报告消息/简单/员工

说明请求的资源不可用。

apache tomcat/7.0.37版**
我不知道我做错了什么。如果有人指引我,我会很高兴的

np8igboo

np8igboo1#

您希望仔细检查servletMap规则的大小写。你写道:

<servlet-mapping>
<servlet-name>simple</servlet-name>
<url-pattern>/simple</url-pattern>
</servlet-mapping>

你应该写的地方:

<servlet-mapping>
<servlet-name>simple</servlet-name>
<url-pattern>/Simple</url-pattern>
</servlet-mapping>

另外,你没有一个模式,导致/简单/员工。您可能只想重定向到/simple,或者将模式编辑为/simple/employee
如果您只想重定向到/simple,请编辑此行:

<form action="employee" method="Post">

收件人:

<form action="/Simple" method="Post">
h79rfbju

h79rfbju2#

你有错误的网址/链接

**http状态404-/simple/employee

根据web.xml

<url-pattern>/simple</url-pattern>

你的表格 action 必须指向简单

<form action="simple" method="Post">

或者只是在web.xml中进行更改

<url-pattern>/employee</url-pattern>
0vvn1miw

0vvn1miw3#

在login.jsp action=“employee”中,用action=“employee”更改它,因为您不能给出正确的servlet名称,所以它给出404页未找到。

watbbzwu

watbbzwu4#

在login.jsp action=“employee”中,使用action=“employee”更改它,因为java是区分大小写的,所以您将看到404页未找到。

相关问题