Java ajax 从 jsp 到 servlet 传递值

6
我将尝试通过ajax从jsp向servlet传递诸如id等基本值。我已经尝试了所有方法,但只有null被传递。即使console.log(val)也没有在浏览器控制台中打印任何内容。
我的理解是:网页具有表单值,onsubmit调用js文件。js使用ajax调用servlet并传递表单数据。Servlet通过request.getParameter(val)获取来自ajax的数据。
以下是我的代码: Main.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>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.0/jquery.min.js" type="text/javascript">
<script src="js/main.js" type="text/javascript"></script>
</head>
<body>

<form method="post" action="Main" id="firstform">
    <h1>Enter name:</h1>
    <input type="text" name="id" id="id" />
    <input type="submit" name="submit"/>
</form>

</body>
</html>

main.js

var form = $('#firstform');
console.log("gi");
form.submit(function()
{
    $.ajax({
        url: 'Main',
        data: form.serialize(),
        type: 'post',
        success: function(data){ 
            console.log(data);
        }
            });

    //return false;

});

Main.java

package servlets;

import java.io.IOException;
import java.io.PrintWriter;

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

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

    /**
     * @see HttpServlet#HttpServlet()
     */
    public Main() {
        super();
        // TODO Auto-generated constructor stub
    }

    /**
     * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
        int ids;
        response.setContentType("text/html;charset=UTF-8");

        PrintWriter out = response.getWriter();
        String val = request.getParameter("id");
        System.out.print(val);
        if(val != null){
            ids = Integer.parseInt(val);
            out.print(ids); //
        }

    }

    /**
     * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
    }

}

问题:
1)从JSP传递值到servlet
2)控制台日志在浏览器控制台上不打印任何内容

1)已解决,但2)仍未解决。


给这个<input type="text" id="id" />添加一个name属性。 - user3470953
将 <input type="text" id="id" /> 更改为 <input type="text" id="id" name="id" />。 - user3470953
尝试过@sblog.in,但仍然无法工作。 - fscore
尝试在form.submit()内部记录并查看获取的值。还要检查form.serialize()。 - user3470953
@fscore,你得到了你的答案吗? - Santino 'Sonny' Corleone
3个回答

4
在main.js文件中,类型为type: 'post' ,但是你在get方法中编写了代码,请将type:'get' 加入其中。

我现在已经改成了“post”,但仍然没有结果。它甚至不像这里所述的那样在Java控制台上打印 - System.out.print(val); - fscore
所以类型应该是“get”,而不是“post”……然后它就可以工作了 :) 谢谢 - fscore
我接受了你的答案,尽管console.log仍然无法工作。 - fscore

3
你的输入字段中没有name属性。当你进行操作时,需要添加name属性。
String val = request.getParameter("id"); 

在servlet中,它会搜索具有 name="id" 的输入字段,但是在您的表单中没有任何内容,因此它将返回null;
给输入字段命名,例如:
<input type="text" id="id" name="id"/>

正如sanjay所说,你的ajax使用了post方法,请将其更改为get方法。


@fscore 首先尝试提交表单而不使用ajax,然后让我知道你是否得到任何值。 - SpringLearner
@fscore 你是指这一行 console.log("gi"); 吗? - SpringLearner
是的,它不打印。实际上,即使我使用console.log(id),它也不会打印。 - fscore
如果没有错误,那么您应该至少在控制台中看到这个 @fscore console.log("gi");。至少 gi 将被打印。 - SpringLearner

0

针对 console.log(data) 问题,可能是因为 $.ajax() 函数对响应类型感到困惑,尝试这样做:

  • Ajax

    $.ajax({
        url: 'Main',
        data: form.serialize(),
        type: 'post',
        dataType:'text/plain',
        success: function(data){ 
            console.log(data);
        }
    });
    
  • Servlet

    response.setContentType("text/plain;charset=UTF-8");
    
  • Ajax

    $.ajax({
        url: 'Main',
        data: form.serialize(),
        type: 'post',
        dataType:'text/plain',
        success: function(data){ 
            console.log(data);
        }
    });
    
  • Servlet

    response.setContentType("text/plain;charset=UTF-8");
    

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接