无法从servlet访问使用jquery创建的表

时间:2009-12-23 14:30:20

标签: java jquery html servlets

根据stackoverflow提供的帮助,我创建了带有hiddenfields的表,将值传递给servlet,但在servlet中,我无法获取输入字段的值。

这是我创建表的jQuery代码:

$("#linkInstr").click(function() {
    var arr = new Array();
    var cdid = $("#cboinstr option:selected");
    var code = $("#cbocode option:selected");
    $.get("trnDC?caseNo=21&insid="+cdid.text(), function(data) {
        arr = data.split(",");
        var contents = '<tr><td><input type="checkbox" id="chk_select'+counter+'" /></td><td><input type="hidden" id="txtCodeid'+counter+'" value="'+code.text()+'"/> ' + code.text()+ '</td><td><input type="hidden" id="txtInstrid'+counter+'" value="'+cdid.text()+'"/>' + cdid.text() + '</td><td>' + arr[0] + '</td><td>' + arr[1] + '</td><td>' + arr[2] + '</td></tr>';
        alert(contents);
        $("#tblDetails").append(contents);
        counter++;
    })
})

这是我的Servlet代码:

int noOfRows = Integer.parseInt(request.getParameter("noOfRows"));

for (int i = 0; i < noOfRows; i++) {
    int j = i + 1;
    String codeid = request.getParameter("txtCodeid" + i);
    throw new Exception(request.getParameter("txtCodeid" + i));
    String instrId = request.getParameter("txtInstrid"+i);
    st.executeUpdate("insert into trndcdtls values(" +ccode +"," +fyear_code +"," +Dcno +"," + j +",'" + codeid +"','" + instrId +  "','"+status+"')");
}

我自己有目的地抛出异常,检查任何值是否可用,但它没有显示任何值。

1 个答案:

答案 0 :(得分:4)

您需要为输入字段指定名称。这将成为请求参数名称。

因此,而不是

<input id="foo">
<input id="bar">

你需要

<input name="foo">
<input name="bar">

ID纯粹是为了识别客户端的元素,而不是服务器端的元素。您可以添加它们,但不会将它们发送到服务器端。只有name - value对输入元素将作为请求参数发送到服务器端。

也就是说,请在Java代码中使用PreparedStatement以避免SQL injection风险。更进一步,令我惊讶的是,您在流程中间使用Exception编译了Java代码。它会给出“无法访问的代码”错误。