1.项目介绍

   典型电子商务系统(在线购物平台)。模拟了当当系统部分功能。

2.功能需求

    1)用户管理模块(3天)user

         实现登录、注册功能

    2)产品浏览模块(2天)main

         实现主界面和类别浏览功能

    3)购物车模块(1.5天)cart

         实现购买、变更数量、删除等功能

    4)生成订单模块(1.5天)order

         订单确认、填写送货地址、生成订单功能

3.技术应用

   1)技术架构

        Struts2,JDBC(连接池),jQuery,Ajax

   2)设计思想

       MVC和分层设计思想

       a.显示层:JSP组件(jQuery,Ajax)

       b.控制层:Struts2控制器组件、Action组件

       c.业务层:Bean组件

       d.数据访问层:DAO组件(JDBC)


4.数据库设计

    1)数据库导入

         create database dangdang;      //创建库

         use dangdang;       //进入dangdang库

         set names utf8;    //设置连接和发送SQL编码

         source 路径/dangdang.sql; //导入sql文件

    2)数据表功能

         a.d_user(用户信息表)

            存储了用户信息,涉及登录和注册功能

         b.d_receive_address(收货地址信息表)

            存储了收货地址信息,涉及填写送货地址功能

         c.d_category(类别信息表)

             存储了图书的类别信息,涉及主界面左侧类别菜单功能

         d.d_book(图书信息表)

             存储了图书的特有信息,涉及产品浏览等功能

         e.d_product(产品信息表)

             存储了各类型产品的共通信息字段。

         f.d_category_product(类别和产品对应关系表)

             存储了类别和产品之间包含关系,涉及产品浏览功能

         g. d_order(订单信息表)

             存储了订单信息,涉及创建订单功能

         h. d_item(订单明细表)

             存储了订单中所购买的商品信息,涉及创建订单功能。


5. 搭建工程结构

    1)引入需要的开发包

          struts2开发包

          jdbc开发包

          dbcp连接池开发包

    2)src文件结构

         org.tarena.dang.action  :控制层

         org.tarena.dang.action.user :用户模块的action

         org.tarena.dang.action.main  :产品浏览的action

         org.tarena.dang.action.order :订单的action

         org.tarena.dang.action.cart :购物车的action

         org.tarena.dang.service :业务层

         org.tarena.dang.dao :数据访问层

         org.tarena.dang.entity :实体类

         org.tarena.dang.util :工具类

         org.tarena.dang.interceptor :拦截器

    3)struts配置文件结构

         web.xml(配置Filter控制器)

         struts.xml (struts主配置文件)

         struts-user.xml(用户模块配置文件)

         struts-main.xml(浏览模块配置文件)

         struts-order.xml(订单模块配置文件)

         struts-cart.xml(购物车模块配置文件)


    4)WebRoot文件结构

         /user/* :用户管理的JSP

         /cart/* :购物车的JSP

         /order/* :订单的JSP

         /main/* :产品浏览的JSP

         /common/* :页眉、页脚等共同JSP

         /js/*      : 放置js脚本文件

         /css/* :放置css样式文件

         /images/* :放置页面图片文件

         /productImages/* :放置产品图片


-----------------连接池的优点-----------------

a.可以管理Connection对象,并且将Connection数量控制在一个安全范围内。提高数据库的访问安全性。

b.连接池中的Connection对象与数据库保持连接状态,避免频繁的建立和销毁连接。


============用户管理模块==============

1.注册需求

   1)表单验证(采用js+Ajax)

         邮箱:非空、格式、唯一性(ajax)

         昵称:非空、格式

         密码:非空、格式

         确认密码:非空、与密码一致

         验证码:非空、正确性(ajax)


   2)将表单信息写入数据表d_user

         编写实体类、DAO、Action

   3)给用户邮箱发送验证码

         引入commons-email.jar,email.jar

         参考EmailUtil工具类代码

   4)进入邮箱验证页面verify_form.jsp


2.邮箱验证

   1)表单验证

       验证码:非空、正确性(ajax)

      正确后跳转到成功提示界面:window.location = "register_ok.jsp";

   2)Action逻辑

      a.利用验证码去d_user检查

      b.如果正确,将d_user的is_email_verify字段更新成Y;不正确在verify_form.jsp提示“验证失败”

      c.跳转到register_ok.jsp

3.用户登录

    1)表单验证

         邮箱:非空、格式

         密码:非空

    2)Action逻辑

      a.检测Email和密码是否正确,失败回到login_form.jsp提示

      b.检测is_email_verify邮箱是否通过验证,未通过进入verify_form.jsp

      c.更新最后一次登录时间last_login_time和IP地址last_login_ip。

      d.将用户信息放入session。

      e.都正确进入/main/main.jsp

4.main.jsp页面的页眉部分,显示用户是否登录的状态

   如果用户已登录,显示"欢迎XXX,【登出】"

   如果用户未登录,显示"【登录】【注册】"


数据库 模型 


首页展示: