繁体   English   中英

Java Web服务中的NoSuchMethodException

[英]NoSuchMethodException in Java web service

我创建了一个Java Web服务,该服务需要添加人员,检索所有人员以及检索单个人员。 除了增加人员,一切都在进行。 我收到了NoSuchMethodException。 我已经浏览了100次代码,似乎没有任何改变。

首先,我有一个带有文本字段的jsp页面来添加一个工作人员:

<fieldset>
        <form action="#">
            <legend>Add Staff Members</legend>
            <label>First name: <input type="text" id="forename" /> </label> 
            <br /> 
            <label>Last name: <input type="text" id="surname" /></label>
            <br /> 
            <label>Email: <input type="text" id="email" /></label>
            <br /> 
            <label>Phone Number: <input type="text" id="phone_num" /></label>
            <br /> 
            <label>Address: <input type="text" id="address" /></label>
            <br /> 
            <input type="button" value="Add Staff"
                onclick='addStaffMember("forename", "surname", "email", "phone_num", "address", "staff_result_add")' />
        </form>
        <div id="staff_result_add"></div>
    </fieldset>

当用户单击按钮时,将调用javascript函数。 js函数如下:

function addStaffMember(firstname, lastname, address, phone_num, email, resultRegion) {
var web_xml_address = "add-staff-member";
var data = "&firstname="
        + getValue(firstname) + "&lastname=" + getValue(lastname) + "&address=" + getValue(address)
        + "&phone_num=" + getValue(phone_num) + "&email=" + getValue(email);
var address = web_xml_address + "?" + data;
ajaxResult(address, resultRegion);

}

然后转到我的web.xml文件以找到相关的Java类:

 <servlet>
    <servlet-name>Add Staff Servlet</servlet-name>
    <servlet-class>com.coreservlets.AddStaffMember</servlet-class>
 </servlet>
 <servlet-mapping>
    <servlet-name>Add Staff Servlet</servlet-name>
    <url-pattern>/add-staff-member</url-pattern>
 </servlet-mapping>

然后,这最后转到我的Java方法:

package com.coreservlets;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;



public class AddStaffMember {

public Connection connection;

public AddStaffMember(String dbName, String username, String password)     {
    String url = "jdbc:mysql://mudfoot.doc.stu.mmu.ac.uk:3306/" + dbName;

    try {
        Class.forName("com.mysql.jdbc.Driver").newInstance();
        System.out.println("Connected");
        connection = DriverManager.getConnection(url, username, password);
    } catch (InstantiationException | IllegalAccessException
            | ClassNotFoundException | SQLException e) {
        e.printStackTrace();
        System.out.println("Disconnected");
    }
 }

public void addStaffMember(StaffInfo staff) throws SQLException {
    String query = "insert into staff_info (staff_id, forename, surname, address, phone_number, email) values (?,?,?,?,?,?)";
    try {
        PreparedStatement statement =         connection.prepareStatement(query);
        statement.setInt(1, staff.getStaffID());
        statement.setString(2, staff.getForename( ) );
        statement.setString(3, staff.getSurname( ) );
        statement.setString(4, staff.getLocation( ) );
        statement.setString(5, staff.getPhone( ) );
        statement.setString(6, staff.getEmail( ) );         
        statement.executeUpdate();
    } catch (SQLException e) {
        e.printStackTrace();
    }
}

}

然后由servlet调用以执行:

 package com.dunn.servlets;

import java.io.IOException;
import java.sql.SQLException;

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

import com.coreservlets.AddStaffMember;
import com.coreservlets.StaffInfo;

/**
 * Servlet implementation class AddStaffMemberServlet
 */
@WebServlet("/AddStaffMemberServlet")
public class AddStaffMemberServlet extends HttpServlet {
private static final long serialVersionUID = 1L;

/**
 * @see HttpServlet#HttpServlet()
 */
public AddStaffMemberServlet() {
    super();
}

/**
 * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse
 *      response)
 */
public void doGet(HttpServletRequest request,
        HttpServletResponse response) throws ServletException, IOException {
    doPost(request, response);
}

/**
 * @see HttpServlet#doPost(HttpServletRequest request,   HttpServletResponse
 *      response)
 */
public void doPost(HttpServletRequest request,
        HttpServletResponse response) throws ServletException, IOException {
    String forename = request.getParameter("forename");
    String surname = request.getParameter("surname");
    String address = request.getParameter("address");
    String email = request.getParameter("email");
    String phone = request.getParameter("phone");

    StaffInfo staffMember = new StaffInfo();

    //staffMember.setStaffID(100);
    staffMember.setForename(forename);
    staffMember.setSurname(surname);
    staffMember.setLocation(address);
    staffMember.setPhone(phone);
    staffMember.setEmail(email);

    AddStaffMember addStaffMember = new AddStaffMember("staff_info", "dunnj", "grustpOl8");
    try {
        addStaffMember.addStaffMember(staffMember);
        System.out.println(" Member added ");
    } catch (SQLException e) {
        e.printStackTrace();
        System.out.println(" Errorr ");

    }


}

}

我不知道这是怎么回事,无法在网上找到任何相关的信息!!!

一些帮助将不胜感激!

我得到的错误是:

在此处输入图片说明

您的类AddStaffMember需要一个无参数的构造函数。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM