0

美好的一天人们。

我今天花了一整天的时间想一个非常难的问题。您可以在此 url 上获得的所有完整代码中的第一个:https://github.com/Vadim32/RemoteWebContent

好的,现在是问题:我需要制作用户订单的购物车。用户可以订购以下活动:开发软件或计算机维护。所以为此我有servlet:

public class EventNewUserServlet extends HttpServlet {


    //-------------------------Variables------------------------

        private static final long serialVersionUID = 1L;

        protected WebContentDAOIF webContentDAOIF;


    //-------------------------Servlet methods------------------  

     public void init() {
         /*Getting bean from spring ContextLoaderListener and inject it to webContentDAOIF variable 
           to use webContentDAOIF in this servlet*/
        ApplicationContext context = WebApplicationContextUtils.getWebApplicationContext(getServletContext());
            webContentDAOIF = context.getBean("webContentDAOImpl", WebContentDAOIF.class);
        }



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


            List<UserEvents> userEventsList = new ArrayList<UserEvents>(2); //This list store all user orders 



        }
}

所以我有List<UserEvents> userEventsListdoPost 方法,它将存储用户订购的事件,例如:ComputerMaintenanceEvent 或 SoftwareDevelopmentEvent,它们都是从 UserEvents 类扩展的

在这个jsp页面上:

<html>

        <head>
            <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
            <title>Order event page</title>

            <!-- Bootstrap css responsive-->
            <link href="resources/css/bootstrap.css" rel="stylesheet">
            <link href="resources/css/bootstrap-responsive.css" rel="stylesheet">

        </head>

        <body>

            <!-- JQuery and Bootstrap file-->
            <script src="resources/js/jquery-1.10.2.min.js"></script>
            <script src="resources/js/bootstrap.min.js"></script>
            <script src="resources/js/jquery.scrollTo.js"></script> 
            <script src="resources/js/jquery.nav.js"></script>

            <h1>New user</h1>
            <form action="new-user-event" method="post">

                    <input type="hidden" name="userSessionId" value="${userSessionId}">

                <table align="center">

                    <tr><td>Event type:</td><td>
                        <select name="event_type">
                            <option>Choose event type</option>
                            <option>Computer Maintenance Event</option>
                            <option>Software Development Event</option>
                        </select>
                    </td></tr>
                    <tr><td>Event date:</td> <td><input type="text" class="span2" name="user_event_date"></td></tr>
                    <tr><td>Event description:</td> <td><textarea rows="5" name="description"></textarea></td></tr>
                    <tr><td>Additional Info:</td> <td><input type="text" class="span2" name="additional_info"></td></tr>

                    <tr><td>First name:</td> <td><input type="text" class="span2" name="first_name"></td></tr>
                    <tr><td>Last name:</td> <td><input type="text" class="span2" name="last_name"></td></tr> 
                    <tr><td>E-male:</td> <td><input type="text" class="span2" name="e_male"> </td></tr>
                    <tr><td>Address:</td> <td> <input type="text" class="span2" name="address"></td></tr>
                    <tr><td>Phone number:</td> <td> <input type="text" class="span2" name="phone_number"></td></tr>

                    <tr><td><input type="submit" value="Regester user"></td></tr>

                </table>

            </form>

        </body>

    </html>

用户将订购实际事件(将下订单)。

所以要求是:

  • 我不想让另一个 servlet 将对象存储在列表中,而另一个 servlet 将事件列表存储在数据库中。

  • 我想首先在会话中收集事件对象,或者只是将它们添加到没有 servlet 的列表中(可能以某种方式使用 jsp 或 javascripts),例如当用户在网页上有添加按钮并且他可以在其中添加任意数量的事件时列表,然后通过同一jsp页面上的表单提交按钮将触发实际的servlet将所有收集的事件从列表保存到数据库?

是否可以这样做?

感谢开发人员,希望您能帮助我阅读一些很棒的教程或文档。

4

1 回答 1

0

在我看来,如果单击添加按钮,您希望临时存储事件。最后只有点击提交按钮才会将之前临时存储的事件更新到数据库中,对吧?

答案很简单,就像你在亚马逊购物,你首先将一些产品添加到购物车中,你选择的产品将被存储到 cookie 中,该 cookie 保留在客户的计算机中。最后,您检查您选择的所有产品,这里一个 servlet 将从 cookie 中读取存储的产品,然后将它们保存到数据库中。所以我认为你可以按照这种方式。

于 2013-11-04T02:06:04.867 回答