Ajax从JSP发布到Java中的servlet?

时间:2017-07-11 13:45:41

标签: java jquery ajax jsp servlets

所以,这就是我想要实现的目标。假设我有一个表单,我填写详细信息并单击提交。数据将插入数据库。现在,我的想法是,我想使用ajax显示刚刚添加到数据库的数据,而无需刷新页面。我正在学习使用ajax的想法,所以我有点迷失。有人可以建议任何建议。 我的想法是,当我点击提交时,将会触发两个事件。一种是将数据插入数据库,另一种是从数据库获取数据并将其显示在标记内。

这是我的servlet中的get方法。 Home.java

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
         PrintWriter out = response.getWriter();
         response.setContentType("text/html");
         out.println("<html><body>");
         try {
            Class.forName("com.mysql.jdbc.Driver");
            Connection con= (Connection) DriverManager.getConnection("jdbc:mysql://localhost/apiprovider","root","");
             Statement stmt = con.createStatement();
             ResultSet rs = stmt.executeQuery("select * from apiinfo");
            // out.println("<table border=1 width=50% height=50%>");
            // out.println("<tr><th>EmpId</th><th>EmpName</th><th>Salary</th><tr>");
             while (rs.next()) {
                 String n = rs.getString("apiname");
                 String nm = rs.getString("apiendpoint");
                 int s = rs.getInt("id"); 
                 response.getWriter().write(n);

                // out.println("<tr><td>" + n + "</td><td>" + nm + "</td><td>" + s + "</td></tr>"); 
             }
           //  out.println("</table>");
            // out.println("</html></body>");
             con.close();
            }
             catch (Exception e) {
             out.println("error");
         }
     }

回到Home.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>
<div id="ajaxresponse">


</div>
<form>
 API Name:<br>
  <input type="text" id = "apiname" name="apiname">
   API ENDPOINT:<br>
  <input type="text" id ="apiendpoint" name="apiendpoint">
  <br>
  API VERSION:<br>
  <input type="text" id="apiversion" name="apiversion">
   ACCESSIBLE:<br>
  <input type="checkbox" name="source" value="internet"> Internet<br>
    <input type="checkbox" name="source" value="vpn"> VPN<br>

  <br><br>
  <input type="submit" formaction="Home" method="post" value="Submit">
  <br>
    <input type="submit" name="Submit" value="Submit">

</form> 
<script src="https://code.jquery.com/jquery-3.2.1.min.js"></script>
<script type="text/javascript">
$(document).ready(function() {
    $('#Submit').click(function(event) {
        console.log("You clicked me");
        $.ajax({
              url: "Home",
              sucess:function(result){

              }
            });
    });
});
</script>
</body>
</html>

2 个答案:

答案 0 :(得分:0)

我认为你不需要举办两场比赛。您应该向servlet发送ajax调用并从中获取格式正确的JSON(来自DB的数据)。在这种情况下,当您收到数据时,您知道插入成功。在你的sucess函数之后,你需要解析来自servlet的响应并使用javaScrip set数据到你表单的元素。

答案 1 :(得分:0)

您可以根据故障转移情况以多种方式实现此目标 请通过此链接更好地了解ajax with servlets.
如果此次调用成功,则单击“提交”按钮首先将数据插入数据库然后再触发一次ajax调用以从数据库中获取数据以显示请在下方检查sudo代码

<script type="text/javascript">
$(document).ready(function() {
    $('#Submit').click(function(event) {
        console.log("You clicked me");
        $.ajax({
              url: "Home",
              sucess:function(result){
                // here call another servlet which will get the data
              }
            });
    });
});
</script>

如果插入调用失败,您可以提及诸如“插入失败,请稍后再试”的通用消息