从jsp下拉框获取数据库内容到servlet获取选择结果!
Q:
如何从数据库里提取出学院名字(之所以不采用手动形式的下拉框是因为学院信息可能会变动 从数据库提取保证了信息的时效性准确性)显示在下拉框中(用于注册时供用户选择所属学院)
A: jsp中这么写(注意name属性写在select标签中,此name即为传回servlet的值)
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%
DepartmentDAO dep=new DepartmentDAO();
List<Department> list=dep.Department_information();
request.setAttribute("list",list);
%>
<tr>
<td>学 院:</td>
<lable>学 院:</lable>
<select name="dept_id">
<option value="">请选择:</option>
<c:forEach items="${list}" var="dep">
<option value="${dep.dept_id}">${dep.dept_name}</option>
</c:forEach>
</select>
</tr>
Q:
如何在servlet中获取到从jsp传来的值?
A:因为在设计数据库的注册表时用到的属性时学院id,故在上述jsp中设置value为学院id。
!!!!!!name为传回来的学院id的变量名,value为变量的值。
int dept_id=Integer.parseInt(request.getParameter("dept_id"));
反思:
这次在name和value的意义上使用错误,导致小小下拉框我一直都get不到我要的学院id 出错位在java类的getParameter那句语句。
为什么获取不到东西呢?一开始是这么写的:name位置错误
<select >
<option value="">请选择:</option>
<c:forEach items="${list}" var="dep">
<option name="dept_id" value="${dep.dept_id}">${dep.dept_name}</option>
</c:forEach>
</select>
中间怀疑人生甚至在option里加了id排列组合试了好几次都报500…结果是name位置不对导致…在这块花费了较大时间实属不该。写下这篇日志,铭记于心,此错再犯我就是狗!