Перезапустите сервлет после отправки формы

#java #xml #jsp #servlets

Вопрос:

Я довольно новичок в использовании сервлетов с JSP, и у меня возникли проблемы с перенаправлением на начало домашней страницы сервлета JSP после отправки моей формы jsp, и я не уверен, как выполнить эту задачу или возможно ли вообще это сделать, методы, которые я пробую, в лучшем случае вернули домашнюю страницу jsp, но без функции по умолчанию сервлета, вызываемой для извлечения данных из jdbc. я пробовал sendredirect() и запрашивать диспетчера безрезультатно, и любая помощь в том, где я ошибаюсь, была бы признательна.

у меня есть один код сервлета для обработки всех операций, включая вставку и обновление, которые создают проблемы при перенаправлении/перезагрузке

 public class StudentServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;
    private StudentDao studentDao;

    public StudentServlet() {
        this.studentDao = new StudentDao();
    }

    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doGet(request, response);
    }

    
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        String sPath = request.getServletPath();
        //switch statement to call appropriate method
        switch (sPath) {
            case "/new":
                try {
                    showNewForm(request, response);
                } catch (ServletException | IOException e) {
                    e.printStackTrace();
                }
                break;
            case "/insert":
                try {
                    insertStudent(request, response);
                } catch (SQLException | IOException e) {
                    e.printStackTrace();
                } 
                break;
            case "/delete":
                try {
                    deleteStudent(request, response);
                } catch (SQLException | IOException e) {
                    e.printStackTrace();
                }
                break;
            case "/update":
                try {
                    updateStudent(request, response);
                } catch (SQLException | IOException e) {
                    e.printStackTrace();
                }
                break;
            case "/edit":
                try {
                    editStudent(request, response);
                } catch (ServletException | IOException e) {
                    e.printStackTrace();
                }
                break;
            case "/StudentServlet":
                try {
                    listAllStudents(request, response); 
                } catch (ServletException | IOException | SQLException e) {
                    e.printStackTrace();
                } 
                break;
            default:
                try {
                    listAllStudents(request, response); //home page = .../week04/StudentServlet
                } catch (ServletException | IOException | SQLException e) {
                    e.printStackTrace();
                } 
                break; 
            } 
    }

    // functions to fetch data from studentDao and display data on appropriate jsp
    private void listAllStudents(HttpServletRequest request, HttpServletResponse response) 
            throws ServletException, IOException, SQLException {
        List<Student> allStudents = studentDao.selectAllStudents();
        request.setAttribute("listStudents", allStudents);
        RequestDispatcher dispatch = request.getRequestDispatcher("student-list.jsp"); 
        dispatch.forward(request, response);
    }
    
    private void showNewForm(HttpServletRequest request, HttpServletResponse response) 
        throws ServletException, IOException {
        RequestDispatcher dispatch = request.getRequestDispatcher("student-form.jsp");
        dispatch.forward(request, response);
    }

    private void insertStudent(HttpServletRequest request, HttpServletResponse response) 
            throws SQLException, IOException{
        String firstname = request.getParameter("firstname");
        String lastname = request.getParameter("lastname");
        String email = request.getParameter("email");
        Student newStudent = new Student(firstname, lastname, email);
        studentDao.insertStudent(newStudent); //student object inserted to table 
        response.sendRedirect("/StudentServlet"); //redirect to home page
    }
    
    private void deleteStudent(HttpServletRequest request, HttpServletResponse response) 
            throws SQLException, IOException {
        int id = Integer.parseInt(request.getParameter("id"));
        studentDao.deleteStudent(id); //student object deleted
        response.sendRedirect("/StudentServlet");
    }
    
    private void updateStudent(HttpServletRequest request, HttpServletResponse response) 
            throws SQLException, IOException{
        String sId = request.getParameter("id");
        int id = Integer.parseInt(sId);
        String firstname = request.getParameter("firstname");
        String lastname = request.getParameter("lastname");
        String email = request.getParameter("email");
        Student updateStudent = new Student(id, firstname, lastname, email);
        studentDao.updateStudent(updateStudent); //student object updated
        response.sendRedirect("/StudentServlet");
    }
    
    private void editStudent(HttpServletRequest request, HttpServletResponse response) 
            throws ServletException, IOException {
        int id = Integer.parseInt(request.getParameter("id"));
        Student currentStudent = studentDao.selectStudent(id);
        RequestDispatcher dispatch = request.getRequestDispatcher("student-form.jsp"); //student form called with current student info loaded
        request.setAttribute("student", currentStudent); 
        dispatch.forward(request, response);
    }
    
}

 

вот мой xml-файл:

 <?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:web="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd http://java.sun.com/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee" id="WebApp_ID" version="2.4">

 
  
  
  <servlet>
    <servlet-name>StudentServlet</servlet-name>
    <servlet-class>week04.web.StudentServlet</servlet-class>
  </servlet>
  
  <servlet-mapping>
    <servlet-name>StudentServlet</servlet-name>
    <url-pattern>/</url-pattern>
    <url-pattern>/StudentServlet</url-pattern>
    <url-pattern>/new</url-pattern>
    <url-pattern>/update</url-pattern>
    <url-pattern>/insert</url-pattern>
    <url-pattern>/delete</url-pattern>
    <url-pattern>/edit</url-pattern>
  </servlet-mapping>
</web-app>
 

вот моя домашняя страница JSP, я назвал ее student-list.jsp

 <%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1" import="java.util.*" import="week04.model.Student"%>

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, intial-scale=1 shink-to-fit=yes">

    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/css/bootstrap.min.css" 
    integrity="sha38-...." crossorigin="anonymous">
</head>
<body>
    <nav class="navbar navbar-dark bg-primary pd-8">
         <a class="navbar-brand">amp;nbsp;amp;nbsp;amp;nbsp;amp;nbsp;XYZ University</a>
    </nav>
    <div class="container-fluid">
    <div class="container">

            <div class="form container-fluid p-4">
               <a href="<%=request.getContextPath()%>/new" class="btn btn-success" >Add
                    Student</a>
            </div>
            <br>
            
            <!--Assigning ArrayList object containing student data to the local object -->
            <% ArrayList<Student> studentList = (ArrayList) request.getAttribute("listStudents"); %> 
            <table class="table table-bordered">
            
                <thead>
                    <tr>
                        <th>First Name</th>
                        <th>Last Name</th>
                        <th>Email</th>
                        <th>Actions</th>
                    </tr>
                </thead>
                <tbody>
                    <%
                     if(request.getAttribute("listStudents") != null)  {
                            Iterator<Student> iterator = studentList.iterator();
                            while(iterator.hasNext()) {
                                Student studentDetails = iterator.next();
                    %>
                        <tr><td><%=studentDetails.getFirstname()%></td>
                            <td><%=studentDetails.getLastname()%></td>
                            <td><%=studentDetails.getEmail()%></td>
                            <td><a href="<%=request.getContextPath()%>/edit?id=<%=studentDetails.getId()%>">Update</a>
                                amp;nbsp;amp;nbsp;amp;nbsp;amp;nbsp; <a href="<%=request.getContextPath()%>/delete?id=<%=studentDetails.getId()%>">Delete</a></td>
                        </tr>
                    <% 
                            }
                     }
                    %>
                </tbody>
                
            </table>
            </div>
        </div>
         
    </body>
</html>
 

а вот мой файл формы, который обрабатывает вставку и обновление данных:

 <%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, intial-scale=1 shink-to-fit=yes">

    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/css/bootstrap.min.css"
     integrity="sha384-...">
</head>
<body>
    <nav class="navbar navbar-dark bg-primary pd-8">
         <a class="navbar-brand">amp;nbsp;amp;nbsp;amp;nbsp;amp;nbsp;XYZ University</a>
    </nav>
    <div class="container col-md-5 p-4">
        <div class="card">
            <div class="card-body">
        <% System.out.println(request.getAttribute("student")   "hello"); %>
                <% if (request.getAttribute("listStudents") != null || request.getAttribute("student") != null) { %>
                    <form action="<%=request.getContextPath()%>/update" method="post">
                    <% } else { %>
                    <form action="<%=request.getContextPath()%>/insert" method="post">
                    <% } %>
    
                    <div>
                        <h2>
                        <% if (request.getAttribute("student") != null) { %>
                            Edit Student
                        <% } else { %>
                            Add New Student
                        <% } %>
                        </h2>
                    </div>

                <% if (request.getAttribute("student") != null) { %>
                    <input type="hidden" name="id" value="${student.id}" />
                <% } %>

                <fieldset class="form-group">
                    <legend> First Name</legend>
                    <% if (request.getAttribute("student") != null) { %>
                       <input type="text" value="${student.firstname}" class="form-control" 
                       name="fistname" required="required">
                    <% }  else { %>
                        <input type="text" value="" class="form-control" name="firstname" required="required">
                    <% } %>
                </fieldset>
                
                <fieldset class="form-group">
                    <legend>Last Name</legend>
                    <% if (request.getAttribute("student") != null) { %>
                       <input type="text" value="${student.lastname}" class="form-control" 
                       name="lastname" required="required">
                    <% }  else { %>
                        <input type="text" value="" class="form-control" name="lastname" required="required">
                    <% } %>
                </fieldset>

                <fieldset class="form-group">
                <legend>Email</legend>
                <% if (request.getAttribute("student") != null) { %>
                    <input type="text" value="${student.email}" class="form-control" name="email">
                <% }  else { %>
                    <input type="text" value="" class="form-control" name="email">
                <% } %>     
                </fieldset>
                
                <button type="submit" class="t-3 btn btn-success">Save</button>
                </form>
            </div>
        </div>
    </div>
    
</body>
</html>
 

Буду признателен за любую помощь, я не знаю, не ошибаюсь ли я в конфигурации сервлета, xml или конфигурации страницы формы.

Комментарии:

1. Какие-либо исключения в журналах сервера?

2. @Ravi K Сказал да, если я включу инструкцию case /StudentServlet, я получу исключение classnotfoundexception, если я его не включу, я успешно загружу страницу

3. Также я пробовал использовать response.sendRedirect("/") и request.getRequestDispatcher("/") , но они отправляют меня обратно на домашнюю страницу, но теперь данные не вставляются в базу данных

4. Я получаю столбец SQLIntergrityConstraintViolation, имя которого не может быть пустым, хотя я ввел имя в поле

5. @Ravi K Таплиял response.sendRedirect("/") сделал трюк, должен был включить операторы if обратно в код формы jsp, что привело к обновлению и вставке данных/переменных, где они перепутались

Ответ №1:

Вы получаете исключение

SQLIntergrityConstraintViolation: имя столбца не может быть пустым

потому что у вас есть небольшая опечатка в вашей группе форм имени.

 <% if (request.getAttribute("student") != null) { %>
   <input type="text" value="${student.firstname}" class="form-control" 
    name="fistname" required="required">
<% }  else { %>
    <input type="text" value="" class="form-control" name="firstname" required="required">
<% } %>
 

В if блоке <input> текстовое поле name="fistname" написано с ошибкой, в то время name="firstname" как в else блоке оно указано правильно.

Вот почему ваша вставка работает if-else только с else блоком, у которого правильное имя поля. Как только вы исправите эту опечатку, вставка должна начать работать без if-else слишком, как было предписано ранее.