java - 使用select和option标签在jsp中插入数据

标签 java jsp servlets

在我的应用程序中,我正在从表类读取数据,并将 id 值插入表测试中。我通常在jsp中使用表格和插入链接,但这次我需要通过选项标签和插入按钮来显示我的数据。当我单击插入按钮时,出现此错误(引发异常 [java.lang.NumberFormatException: For input string: ""] ,其根本原因 java.lang.NumberFormatException:对于输入字符串:“”)

当我使用表和链接进行插入时没有问题,因此 servlet 和数据库类工作正常。我认为问题可能出在我如何使用选项标签

jsp文件

<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>
        <%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
    
<!DOCTYPE html>
<html>
<head>
<meta charset="ISO-8859-1">
<title>Insert title here</title>
</head>
<body>
<table>
<c:forEach var="tempstudent" items="${select}">
<c:url var="insert" value="add_course">
		<c:param name="command" value="insert"/>
				<c:param name="courseid" value="${tempstudent.id}"/>
			</c:url> 
<tr>
<td>${tempstudent.id}</td>
<td>${tempstudent.name}</td>

<td> 
 	<a href="${insert}" 
 						onclick="if (!(confirm('Are you sure you want to insert this student?'))) return false"> 
						
						insert</a>	 
 						</td>	
</tr>

</c:forEach>




</table>
<form action="add_course" method="GET">
			<input type="hidden" name="command" value="insert" />
<input type="hidden" name="courseid" value="${tempstudent.id}"/>

<select>

<c:forEach var="tempstudent" items="${select}">
<option  value="courseid">${tempstudent.id},<td>${tempstudent.name}</td>
</option>

</c:forEach>

		


</select>
<td><label></label></td>
						<td><input type="submit" value="Save" class="save"/></td>
</form>


</body>
</html>

servlet 文件

  

package com.web;

import java.io.IOException;
import java.util.List;

import javax.annotation.Resource;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.sql.DataSource;

/**
 * Servlet implementation class add_course
 */
@WebServlet("/add_course")
public class add_course extends HttpServlet {
	private dbutil dbutil;
	@Resource(name="jdbc/web_student_tracker")
	private DataSource dataSource;
	@Override
	public void init() throws ServletException {
		//dbutil= new dbutil(dataSource);
		super.init();
		try {
			dbutil=new dbutil(dataSource);
		}
		catch(Exception exc) {
		throw new ServletException(exc);
		}
	}
	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//		List<student> student;
//		try {
//			student = dbutil.getcourse();
//			request.setAttribute("select",student);
//			RequestDispatcher dispatcher = request.getRequestDispatcher("/course.jsp");
//		dispatcher.forward(request,response);
//		} catch (Exception e) {			// TODO Auto-generated catch block
//			e.printStackTrace();
//		}
		try {
			String thecommand=request.getParameter("command");
			if(thecommand==null) {
				thecommand="LIST";
			}
			switch(thecommand) {
			case"LIST":
				listcourse(request,response);
				break;
			case"insert":
				insertcourse(request,response);
				break;
			}
		}
		catch(Exception exc) {
			throw new ServletException(exc);
		}
		
	
	}
	private void insertcourse(HttpServletRequest request, HttpServletResponse response) throws Exception {

		int courseid = Integer.parseInt(request.getParameter("courseid"));
		  student thestudent=new student(courseid);
		  dbutil.insetcourse(thestudent);
		  request.setAttribute("message", "Records loaded successfully");
		  RequestDispatcher dispatcher = request.getRequestDispatcher("/course.jsp");
		  dispatcher.forward(request,response);
//		  int courseid = Integer.parseInt(request.getParameter("courseid"));
//			student thestudent=new student(courseid);
//			dbutil.insetcourse(thestudent);
//			insertcourse(request,response);
		 

	}
	private void listcourse(HttpServletRequest request, HttpServletResponse response) throws Exception {
		List<course> student=dbutil.getcourse();
	request.setAttribute("select",student);
	RequestDispatcher dispatcher = request.getRequestDispatcher("/course.jsp");
	dispatcher.forward(request,response);
	}

}

//数据库类

public List <course> getcourse() throws Exception{
	List<course> course=new ArrayList<>();
	Connection myConn = null;
	Statement myStmt = null;
	ResultSet myRs = null;
	try {
		
		myConn=dataSource.getConnection();
		//String sql="select id from class";
		String sql ="select id,name from class";
		myStmt=myConn.createStatement();
		myRs=myStmt.executeQuery(sql);
		while (myRs.next()) {
	int myid = myRs.getInt("id");
	String myname =myRs.getString("name");
	course tempstudent = new course(myid,myname);

				course.add(tempstudent);
	}
	return course;
}
	finally {
		// close JDBC objects
		close(myConn, myStmt, myRs);
	}		
}

public void insetcourse(student thestudent)throws SQLException  {
	Connection myConn = null;
	PreparedStatement myStmt=null;
	/////////
	try {
		myConn = dataSource.getConnection();
		String sql="insert into test"+"(id)"+"value(?)";
		myStmt=myConn.prepareStatement(sql);

		myStmt.setInt(1,thestudent.getId());
		
		myStmt.execute();
		
	}
	finally {
		close(myConn,myStmt,null);
	}
}

最佳答案

您的<select>标签正在传递一个字符串值,即:<option value="courseid">..</option>这就是为什么你得到 java.lang.NumberFormatException: For input string: ""因为这里value="cousreid"它将通过它是 string 。相反,您的代码应该如下所示 <select> :

<!--giving name attribute to access it in servlet-->
<select name="select">
  <c:forEach var="tempstudent" items="${select}">
  <!--passing id--> 
    <option value="${tempstudent.id}">${tempstudent.id},
      <td>${tempstudent.name}</td>
    </option>
  </c:forEach>
</select>

在你的servlet中访问<select>使用以下代码值:

int courseid = Integer.parseInt(request.getParameter("select"));

关于java - 使用select和option标签在jsp中插入数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60095028/

相关文章:

java - 在测试期间调用预定方法

jquery - 如何使用 jQuery 向后端提交值并接收结果

java - 如何清除状态 401 HttpServletResponse.SC_UNAUTHORIZED?

java - 禁用Tomcat中所有默认的HTTP错误响应内容

java - 从 servlet 获取搜索引擎查询字符串

java - Gradle:在已发布的 dist.zip 的/lib 文件夹中添加 resources.jar 文件以及我的所有其他依赖项

java - 如何验证端口是否开放

java - 使用 Comparable 接口(interface)对任何类型的数据进行排序

java - 如何避免在 Struts 中生成更多的 HTML 元素

javascript - html5 下载属性在 FF 中不起作用