Java ajax 将值从 jsp 传递到 servlet

Posted

技术标签:

【中文标题】Java ajax 将值从 jsp 传递到 servlet【英文标题】:Java ajax passing values from jsp to servlet 【发布时间】:2014-06-22 13:09:39 【问题描述】:

我正在尝试通过 ajax 将基本值(例如 id)从 jsp 传递到 servlet。我尝试了一切,但只有 null 被传递。即使console.log(val) 也不会向浏览器控制台打印任何内容。

我的理解是:网页有表单值,onsubmit调用js文件。 Node.js 有调用 servlet 并传递表单数据的 ajax。 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>

ma​​in.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)console.log 不在浏览器控制台上打印任何内容

1) 有效,但 2) 仍然无效。**

【问题讨论】:

给这个一个name属性 改为 试过@www.sblog.in 但还是不行 尝试登录 form.submit() 并查看您获得的价值。还要检查 form.serialize() @fscore 你得到答案了吗? 【参考方案1】:

在 main.js 中的类型是 type: 'post' 并且您已经在 get 方法中编写了代码 做type:'get'

【讨论】:

我现在改为'post',但仍然没有结果。它甚至不会在此处提到的 Java 控制台上打印 - System.out.print(val); 所以输入应该是'get'而不是发布......然后它起作用了:)谢谢 我接受了你的回答,虽然..console.log 仍然不起作用【参考方案2】:

您的输入字段中没有名称属性。当你在做的时候

String val = request.getParameter("id"); 

然后在 servlet 中它将搜索具有 name="id" 的输入字段,但在您的表单中没有任何内容,因此它将返回 null;

为输入字段命名

<input type="text" id="id" name="id"/>

正如 sanjay 所说,您的 ajax 有 type post 所以也将其更改为 get

【讨论】:

@fscore 首先尝试在不使用 ajax 的情况下提交表单,如果您得到任何值,请告诉我 @fscore 你的意思是这一行 console.log("gi"); 是的,它不打印。事实上,即使我做 console.log(id) 它也不会打印出来 @fscore 如果没有错误,那么您至少应该在控制台中得到这个 console.log("gi");.atleast gi 将被打印出来【参考方案3】:

仅针对 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");

【讨论】:

以上是关于Java ajax 将值从 jsp 传递到 servlet的主要内容,如果未能解决你的问题,请参考以下文章

使用DAO将值从java类传递给jsp页面

JSP 将值从表传递到表单

通过 Laravel 中的 AJAX 发布请求将值从一个视图传递到另一个视图

使用 <a href> 将值从 jsp 传递到 servlet

使用 <a href> 将值从 jsp 传递到 servlet

如何将值从 django 模板化 html 传递到 ajax