Заполнение раскрывающегося списка записями базы данных [дубликаты]

0

Я пытаюсь poulate базы данных GroupNames в моем раскрывающемся списке, используя сервлеты. Как это сделать? Пожалуйста помоги

В моем jsp файле есть:

 <%
ArrayList<String> list1 = (ArrayList<String>)request.getAttribute("res1");
 %>
<select name="GName" >
<%
    for(String list:list1)  
{ %>
<option><%=list%></option>

<% } 
%>

В моем сервлете я выбрал все имена базы данных в arraylist следующим образом:

   ArrayList<String> list = new ArrayList<String>();
            out.println("HI GROUP MEMBER");
            String query="Select GNAME from tbGroup";
            ps = con.prepareStatement(query);
            rs=ps.executeQuery();
            while(rs.next()){
                list.add(rs.getString("GNAME"));


            }
            String[] arr1 = list.toArray(new String[list.size()]);
            request.setAttribute("res1",arr1);

            int i;
            for(i=0;i<list.size();i++){
                out.println(arr1[i]);
            }

Теперь я получаю исключение нулевого указателя в нем. Пожалуйста, помогите, что может быть причиной этого?

Вот полная ошибка:

Stacktrace:] with root cause
java.lang.NullPointerException
at org.apache.jsp.GroupLoginScreen_jsp._jspService(GroupLoginScreen_jsp.java:91)
at org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
at org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:419)
at org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:390)
at org.apache.jasper.servlet.JspServlet.service(JspServlet.java:333)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:304)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at org.netbeans.modules.web.monitor.server.MonitorFilter.doFilter(MonitorFilter.java:393)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:243)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:240)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:164)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:462)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:164)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100)
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:563)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:399)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:317)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:204)
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:311)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1110)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:603)
at java.lang.Thread.run(Thread.java:722)
  • 0
    легче научиться использовать инфраструктуру MVC, такую как распорки, полосы или Spring MVC
  • 0
    @ Java1 Я хочу сделать это в самом html. Не в jsp.
Показать ещё 7 комментариев
Теги:
jsp
servlets
jdbc

2 ответа

0
Лучший ответ
<%
    ArrayList<String> list1 = (ArrayList<String>)request.getAttribute("res1");
 %>
<select name="GName" >
    <%
        for(String list:list1)  
    { %>
    <option><%=list%></option>

   <% } 
    %>
</select>

Используйте это в своем JSP. Код сервлета

            ArrayList<String> list = new ArrayList<String>();
            out.println("HI GROUP MEMBER");
            String query="Select GNAME from tbGroup";
            ps = con.prepareStatement(query);
            rs=ps.executeQuery();
            while(rs.next()){
                list.add(rs.getString("GNAME"));
            }
            request.setAttribute("res1",list);
            RequestDispatcher rd= context.getRequestDispatcher("GroupLoginScreen.jsp");
            rd.forward(request, response);
  • 0
    Все еще то же исключение.
  • 0
    @ user3462609 опубликуйте исключение в вашем вопросе.
Показать ещё 7 комментариев
0

заселить с помощью jstl:

Добавить

<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>

в верхней части jsp.

затем заполните поле выбора следующим образом:

<select>
  <option value="NONE">--None--</option>
  <c:forEach items="${res1}" var="itm">
    <option value="${itm}">${itm}</option>
  </c:forEach>
</select>

и в вашем сервлете:

после извлечения элементов добавьте список в запрос:

request.setAttribute("res1",list);

Примечание: добавьте jstl.jar в свой путь к классам, чтобы использовать c: tag, и избегайте сценариев в jsp

  • 0
    Я попытался это, это дает следующее исключение: org.apache.jasper.JasperException: абсолютный URI : java.sun.com/jsp/jstl/core не может быть разрешен ни в файле web.xml, ни в файлах jar, развернутых с этим приложением
  • 0
    @ user3462609 Вы не добавили jstl в ваш путь к классу, добавьте ссылку, добавленную в начало, проверьте в ответе.
Показать ещё 2 комментария

Ещё вопросы

Сообщество Overcoder
Наверх
Меню