从jsp下拉框获取数据库内容到servlet获取选择结果!

从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>&nbsp;&nbsp;&nbsp;院:</td>
                <lable>&nbsp;&nbsp;&nbsp;院:</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位置不对导致…在这块花费了较大时间实属不该。写下这篇日志,铭记于心,此错再犯我就是狗!

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Servlet 中使用下拉框,可以先在 doGet() 或 doPost() 方法中创建一个 HTML 表单,然后添加一个下拉框元素。下面是一个简单的例子: ```java protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html;charset=UTF-8"); PrintWriter out = response.getWriter(); out.println("<html>"); out.println("<head>"); out.println("<title>Servlet下拉框示例</title>"); out.println("</head>"); out.println("<body>"); out.println("<h1>请选择一个选项:</h1>"); out.println("<form action='servlet_url' method='post'>"); out.println("<select name='option'>"); out.println("<option value='option1'>选项1</option>"); out.println("<option value='option2'>选项2</option>"); out.println("<option value='option3'>选项3</option>"); out.println("</select>"); out.println("<br><br>"); out.println("<input type='submit' value='提交'>"); out.println("</form>"); out.println("</body>"); out.println("</html>"); } ``` 在这个例子中,我们创建了一个 HTML 表单,并添加了一个下拉框元素,其中每个选项都有一个值和显示文本。当用户提交表单时,选择的选项的值将被发送到指定的 Servlet URL,我们可以在 Servlet 中使用 request.getParameter() 方法获取该值。 ```java protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html;charset=UTF-8"); PrintWriter out = response.getWriter(); String option = request.getParameter("option"); out.println("<html>"); out.println("<head>"); out.println("<title>Servlet下拉框示例</title>"); out.println("</head>"); out.println("<body>"); out.println("<h1>您选择的选项是:" + option + "</h1>"); out.println("</body>"); out.println("</html>"); } ``` 在这个例子中,我们在 doPost() 方法中检索名为“option”的参数,并将其打印到响应中。当用户提交表单时,将显示选项的值。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不试一下怎么知道我不行?

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值