Servlet偶尔会从Javascript XHR获取空白数据

Servlet gets blank data from Javascript XHR occasionally

本文关键字:获取 空白 数据 XHR Javascript 偶尔 Servlet      更新时间:2023-09-26

我正在从Javascript发送一些参数到servlet。servlet偶尔会接收一组空参数(通过servlet代码开头的System.out.println()进行检查)。
但是,在调用XHR之前,在Javascript中正确地生成了参数。发送(通过console.log()检查)

附加背景:
servlet从一些数据文件生成一个电子表格,因此它有时可能是位密集型的。 示例代码

web . xml:
<servlet>
    <description>Export Servlet</description>
    <display-name>ExportServlet</display-name>
    <servlet-name>ExportServlet</servlet-name>
    <servlet-class>testpkg.ExportServlet</servlet-class>
</servlet>
<servlet-mapping>
    <servlet-name>ExportServlet</servlet-name>
    <url-pattern>/ExportServlet</url-pattern>
</servlet-mapping>

JAVASCRIPT: common.js: 函数sendDataToServer (args…){

    // ... Some Code...
    var params = "param1=" + value1 + "&param2=" + value2;
    console.log(params); // This works perfectly!
    // AJAX Code
    var xmlhttp;
    // Handling browsers
    if (window.XMLHttpRequest)
    {
        // code for IE7+, Firefox, Chrome, Opera, Safari
        xmlhttp=new XMLHttpRequest();
    }
    else
    {
        // code for IE6, IE5
        xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
    }
    xmlhttp.onreadystatechange = function()
    {
        if (xmlhttp.readyState == 4 && xmlhttp.status == 200)
        {
            // MARKER 1.0
            alert("Success");
        }
    };
    xmlhttp.open('POST', 'ExportServlet', false);
    xmlhttp.setRequestHeader('Content-type','application/x-www-form-urlencoded;charset=UTF-8');
    console.log(params); // This works perfectly!
    // Sending data...
    xmlhttp.send(params); 
}

SERVLET: ExportServlet.java

protected void doPost(HttpServletRequest request, HttpServletResponse response) 
throws ServletException, IOException 
{
    // Init Code...
    response.setHeader("Cache-Control", "no-cache");
    response.setHeader("Pragma", "no-cache");
    request.setCharacterEncoding("UTF-8");
    try
    {
        // Get paramaters
        String sParam1 = request.getParameter("param1");
        String sParam2 = request.getParameter("param2");
        // Test print params...
        System.out.println("Param1 Value = " + sParam1); // Occasionally NULL
        System.out.println("Param2 Value = " + sParam2); // Occasionally NULL
        // More Code...
    }
    catch (Exception ex)
    {
        throw ex;
    }
}

注意:空参数不是由于数据问题,因为我得到这个错误与几分钟前工作的完全相同的数据用例。通常,当重复执行相同的步骤时,这是随机发生的。

知道为什么会这样吗?

try

xmlhttp.open("POST","ExportServlet?param1=" + value1 + "&param2=" + value2,true);
xmlhttp.send();
不是

xmlhttp.open('POST', 'ExportServlet', false);
xmlhttp.send(params);

或者你可以使用JQUERY AJAX

<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7/jquery.min.js"></script>
<script>
function sendDataToServerWithJquery(value1,value2) {
    var params ={"param1":value1,"param2":value2};
    /*
    OR
    var params = "param1=" + value1 + "&param2=" + value2;
    */
             $.ajax({type: "POST",
            url:"ExportServlet",
            data:params,
            success:function(result){
            alert("Success");
            }
          });
}
</script>
<form action="ExportServlet">
<input type="button" onclick="sendDataToServerWithJquery('P1','P2')" value="Submit Values">
</form>

注:用input type="button"代替input type="submit"请参阅

检查下面几行,你就会发现错误了。

var params = "parm1=" + value1 + "&parm2=" + value2;
在javascript

String sParam1 = request.getParameter("param1");
String sParam2 = request.getParameter("param2");
在servlet

我建议您可以使用firebug firefox插件来监控您的网页中的每个XHR调用,并检查XHR post请求发送的确切值,以及请求头和其他一些选项,根据您的场景,如果我是开发人员,我会尝试将parm1和parm2值首先通过本地web表单发送给servlet,如果在逻辑流中没有空值,则切换到XHR调用。顺便说一句,我建议你使用jQuery发送XHR请求,这更容易,检查文档:http://api.jquery.com/jquery.ajax/