Как обновить данные в JSP / Servlet - PullRequest
0 голосов
/ 18 апреля 2020

Я новичок в JSP / Servlet, и я застрял. Я хотел бы редактировать форму, но моя страница пуста после модификации.

Вот пример

1) Я нажимаю на udpate

enter image description here

2) Я изменяю значения

enter image description here

3) Когда я нажимаю на Обновить, у меня появляется пустая страница, я не понимаю проблему?

enter image description here

Вот мой сервлет (UserHandler)

public class UserHandler extends HttpServlet {    
    private static String INSERT = "/user.jsp";
    private static String Edit = "/edit.jsp";
    private static String UserRecord = "/listUser.jsp";
    private UserDao dao;

    public UserHandler() {
        super();
        dao = new UserDao();
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        String forward=""; 
        String action = request.getParameter("action"); 
        if (action.equalsIgnoreCase("delete"))
        { 
            int userId = Integer.parseInt(request.getParameter("userId")); 
            dao.removeUser(userId); 
            forward = UserRecord; 
            request.setAttribute("users", dao.getAllUsers());
        } 
        else if (action.equalsIgnoreCase("editform")){          
            forward = Edit; 
        }
        else if (action.equalsIgnoreCase("edit")){ 
            int userId = Integer.parseInt(request.getParameter("userId")); 
            UserBean user = dao.getUserById(userId); 
            request.setAttribute("user", user); 
        } else if (action.equalsIgnoreCase("listUser")){ 
            forward = UserRecord; request.setAttribute("users", dao.getAllUsers());
        } else { 
            forward = INSERT; 

        } RequestDispatcher view = request.getRequestDispatcher(forward); 

        view.forward(request, response);
    }

    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        String redirect="";

        String action = request.getParameter("action");


        if(action.equalsIgnoreCase("insert"))
        {


            UserBean user = new UserBean();

            user.setfName(request.getParameter("firstName"));
            user.setlName(request.getParameter("lastName"));
            String userid = request.getParameter("userid");
            if(userid == null || userid.isEmpty())
            {
                dao.addUser(user);
            }

            else { 
                user.setUserid(Integer.parseInt(userid)); 
                dao.editUser(user);
            } 

            RequestDispatcher rd = request.getRequestDispatcher(UserRecord); 
            request.setAttribute("users", dao.getAllUsers()); 
            rd.forward(request, response);



        }
    }

И мое редактирование. jsp

<body>
<%
    UserBean user = new UserBean();
%>
<%
    UserDao dao = new UserDao();
%>
<form method="POST" action='UserHandler' name="frmEditUser"><input
    type="hidden" name="action" value="edit" /> <%
    String uid = request.getParameter("userId");
    if (!((uid) == null)) {
        int id = Integer.parseInt(uid);
        user = dao.getUserById(id);
 %>
<table>

    <tr>
        <td>First Name</td>
        <td><input type="text" name="firstName" value="<%=user.getfName()%>"/></td>
    </tr>
    <tr>
        <td>Last Name</td>
        <td><input type="text" name="lastName" value="<%=user.getlName()%>"/></td>
    </tr>
    <tr>
        <td></td>
        <td><input type="submit" value="Update" /></td>
    </tr>
</table>
<%
    } else
        out.println("ID Not Found");
%>
</form>
</body>

Большое спасибо за ваша помощь.

1 Ответ

0 голосов
/ 18 апреля 2020

если ваша БД обновлена, я думаю, что проблема в String UserRecord = "/listUser.jsp"

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...