准备JSP页面以处理数据库条目

时间:2016-05-08 17:23:22

标签: java jsp

我正在尝试创建一个页面,您可以在其中搜索数据库的演出,如果您按Enter键,它会显示所有演出,并且在每次演出后您都有按钮EDIT和DELETE,我将在其中添加正确的功能。

到目前为止,我正在测试我正在按下哪个按钮的打印输出,并查看ID字段是否正确传输。如果我搜索特定的演出,然后在该结果上单击其中一个按钮,它会显示正确的编辑3,删除2
例如,取决于它是哪个演出。但是,当整个页面显示所有演出时,我按下任何演出的按钮,我总是得到编辑1,删除1打印,所以它总是将ID设置为1,无论我点击哪一个。

    <%
if(request.getAttribute("gigs")==null){
    response.sendRedirect("searchGig");
    return;
}
%>

<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>
<%@ page import="bean.Gig"%>
<jsp:useBean id="gigs" type="java.util.ArrayList<Gig>" scope="request" />
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Gigplanner</title>
<link href="gigplanner.css" rel="stylesheet">
</head>
<body>


<form id="msform" action="searchGig" method="post">
  <!-- progressbar -->
  <ul id="progressbar">
    <li><a href="index.jsp">Front Page</a></li>
    <li><a href="addGig.jsp">Add Gig</a></li>
    <li class="active"><a href="searchGig.jsp">Search Gigs</a></li>
    <li><a href="settings.php">Settings</a></li>
  </ul>


<fieldset>
Search Gig: 
<input type="text" name="hakusana" value="" >
<input type="submit" class="show-button" value="Search" >
<br>
<div class="showgig">

<%

for(int i=0;i<gigs.size();i++){
        out.print("<table>");

        out.print("<tr><td>Title:");
        out.print("<td>" +(gigs.get(i).getTitle()+ "</td>"));

        out.print("<tr><td>Venue:");
        out.print("<td>" +(gigs.get(i).getVenue()+ "</td>"));

        out.print("<tr><td>Date:");
        out.print("<td>" +(gigs.get(i).getDate()+ "</td>"));

        out.print("<tr><td>Time:");
        out.print("<td>" +(gigs.get(i).getTime()+ "</td>"));

        out.print("<tr><td>Country:");
        out.print("<td>" +(gigs.get(i).getCountry()+ "</td>"));

        out.print("<tr><td>Address:");
        out.print("<td>" +(gigs.get(i).getAddress()+ "</td>"));

        out.print("<tr><td>Postcode:");
        out.print("<td>" +(gigs.get(i).getPostcode()+ "</td>"));

        out.print("<tr><td>City:");
        out.print("<td>" +(gigs.get(i).getCity()+ "</td>"));

        out.print("<tr><td>Description:");
        out.print("<td>" +(gigs.get(i).getDescription()+ "</td>"));

      out.print("<input type='hidden' name='id' value="+(gigs.get(i).getId()+">"));  
      out.print("<tr><td><input type='submit' name='act' class='show-button' value='edit'></td>");
      out.print("<td><input type='submit' name='act' class='show-button' value='delete'></td>");

        out.print("</tr></table><br>"); 
  }

String act = request.getParameter("act");
String id = request.getParameter("id");
if (act == null) {
    //no button has been selected
} else if (act.equals("delete")) {
    //delete button was pressed
    out.print("DELETE " + Long.valueOf(id));


} else if (act.equals("edit")) {
    //edit button was pressed
    out.print("EDIT " + Long.valueOf(id));
    } else {
    //something else
}


%>
</div>
  </fieldset>
  </form>
  <br />


</body>
</html>

1 个答案:

答案 0 :(得分:1)

请求对象的getParameter()方法依赖于html元素的名称,可能是许多html元素共有的

在您的情况下,该方法将使用与之关联的名称获取第一个元素,而不考虑其他元素。

当您搜索特定的演出时,页面上可能只有一个元素,因此无法识别ID,而当所有这些元素都在页面上时,您无法获得预期的结果。

您应该使用getParameterValues(),然后找到一种方法来检索您感兴趣的特定值(例如,使用与每个演出相关联的复选框,每个演出都有相同的名称属性,但不同的值)或为每个演出创建一个form元素。