我正在从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 + "¶m2=" + 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 + "¶m2=" + 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 + "¶m2=" + 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/