专栏首页Nicky's blogJavaWeb网上商城的设计

JavaWeb网上商城的设计

不知道从什么时候起,我爱上了写博客,对之前学得的只是进行反思。写了几天课程设计,代码量量8、9千左右。 然后下面文字是我在博客上复制过来的,说得很详细

MVC(Model View Controller)设计模式在JavaFX中有着比Swing更好的表现方式。它使得程序界面设计和程序逻辑设计完全分开,便于代码的可读性和以后的可维护性。 JavaEE体系架构采用传统的MVC设计模式,分为Model、View、Controller三层,其中:Model即模型层,定义数据模型和业务逻辑。为了将数据访问与业务逻辑分离,提高业务精度,降低代码之间的耦合,模型层又细分为DAO层与业务层,DAO全称为Data Access Object(数据访问对象),将数据库访问代码封闭起来,Hibernate API也在此封装,不再出现在其他层或向其他层暴露;业务层是整个系统最核心也最具价值的一层,该层封装应用程序的业务逻辑,处理数据,关注客户需求,在业务处理过程中会访问原始数据或产生新数据,或者需要持久化数据,DAO层提供的DAO类能很好地帮助业务层完成数据处理,业务层本身则侧重于对客户需求的理解和业务规则的适应,自然也包括大部分的计算,总体说来,DAO不处理业务逻辑,只为业务层提供辅助,获取原始数据或持久化数据等操作。View即视图层,为最终用户提供一个友好的交互界面,用户可以查看请求结果,也可以通过表单等交互手段实现数据录入。Controller层即控制器,控制器是Model与View的桥梁,将二者很好的衔接,通过View接收用户数据,Controller将数据传输给Model,Model对数据进行处理;或者Model读取数据后,Controller将数据传递给View,View向用户展示数据。一来一往,Controller成了Model与View之间的快乐使者。 

系统构架模式:  MVC构架模式(有用到DAO模式) 

后台管理系统的项目结构有JavaBean类、Dao接口类、Dao接口实现类、控制类,如图a所示:

图a

网上商城前台的项目结构有JavaBean类、Dao接口类、Dao接口实现类、控制类,如图

b所示:

                    图b JSP图片上传

总的说图片上传有两种方式,一种是把图片文件写到数据库中,另一种是存到服务器文件目录中。写到数据库中的图片文件需要转换成二进制流的格式,占用数据库空间比较,适合少量图片的存储,比如说,系统中某些小图标,写到数据库中的优点是比较安全,不容易被用户不小心删除。

下面是我在网上复制的例子:

现在不管是博客论坛还是企业办公,都离不开资源的共享。通过文件上传的方式,与大家同分享,从而达到大众间广泛的沟通和交流,我们既可以从中获得更多的知识和经验,也能通过他人的反馈达到自我改进和提升的目的。

下面我就为大家介绍 web项目中的这一上传功能,那么文件是如何从本地发送到服务器的呢?看我慢慢道来:

首先,我们创建一个新的web工程,在工程的WebRoot目录下新建一个upload文件夹,这样当我们将该工程部署到服务器上时,服务器便也生成个upload文件夹,用来存放上传的资源。

然后,在WebRoot目录下新建一个jsp文件,主要实现的作用就是选择上传的文件,提交至servlet来进行处理

详细代码如下:一个form将文件信息通过post方式传送到指定的servlet

[html] view plaincopy

  1. <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>  
  2. <%  
  3. String path = request.getContextPath();  
  4. String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";  
  5. %>  
  6. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">  
  7. <html>  
  8. <head>  
  9. <base href="<%=basePath%>">  
  10. <title>My JSP 'upload.jsp' starting page</title>  
  11. <meta http-equiv="pragma" content="no-cache">  
  12. <meta http-equiv="cache-control" content="no-cache">  
  13. <meta http-equiv="expires" content="0">      
  14. <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">  
  15. <meta http-equiv="description" content="This is my page">  
  16. <!-- 
  17. <link rel="stylesheet" type="text/css" href="styles.css"> 
  18. -->  
  19. </head>  
  20. <body>  
  21. <form action="/upload/UpLoad" method="post" enctype="multipart/form-data">  
  22. 请选择上传的图片或文件:<input type="file" name="fileName"/><input type="submit" value="上传"/>  
  23. </form>  
  24. </body>  
  25. </html>  

可以看到,我们将数据提交到工程下的upload/UpLoad。

之后,我们就来编写这个servlet——UpLoad.java

[java] view plaincopy

  1. package load;  
  2. import java.io.File;  
  3. import java.io.IOException;  
  4. import java.io.PrintWriter;  
  5. import java.util.List;  
  6. import javax.servlet.ServletContext;  
  7. import javax.servlet.ServletException;  
  8. import javax.servlet.http.HttpServlet;  
  9. import javax.servlet.http.HttpServletRequest;  
  10. import javax.servlet.http.HttpServletResponse;  
  11. import org.apache.commons.fileupload.FileItem;  
  12. import org.apache.commons.fileupload.FileUploadException;  
  13. import org.apache.commons.fileupload.disk.DiskFileItemFactory;  
  14. import org.apache.commons.fileupload.servlet.ServletFileUpload;  
  15. public class UpLoad extends HttpServlet {  
  16. @SuppressWarnings("unchecked")  
  17. @Override  
  18. protected void service(HttpServletRequest req, HttpServletResponse resp)  
  19. throws ServletException, IOException {  
  20. req.setCharacterEncoding("utf-8");  
  21. resp.setContentType("text/html;charset=utf-8");  
  22. //为解析类提供配置信息  
  23. DiskFileItemFactory factory = new DiskFileItemFactory();  
  24. //创建解析类的实例  
  25. ServletFileUpload sfu = new ServletFileUpload(factory);  
  26. //开始解析  
  27. sfu.setFileSizeMax(1024*400);  
  28. //每个表单域中数据会封装到一个对应的FileItem对象上  
  29. try {  
  30. List<FileItem> items = sfu.parseRequest(req);  
  31. //区分表单域  
  32. for (int i = 0; i < items.size(); i++) {  
  33. FileItem item = items.get(i);  
  34. //isFormField为true,表示这不是文件上传表单域  
  35. if(!item.isFormField()){  
  36. ServletContext sctx = getServletContext();  
  37. //获得存放文件的物理路径  
  38. //upload下的某个文件夹   得到当前在线的用户  找到对应的文件夹  
  39. String path = sctx.getRealPath("/upload");  
  40. System.out.println(path);  
  41. //获得文件名  
  42. String fileName = item.getName();  
  43. System.out.println(fileName);  
  44. //该方法在某些平台(操作系统),会返回路径+文件名  
  45. fileName = fileName.substring(fileName.lastIndexOf("/")+1);  
  46. File file = new File(path+"\\"+fileName);  
  47. if(!file.exists()){  
  48. item.write(file);  
  49. //将上传图片的名字记录到数据库中  
  50. resp.sendRedirect("/upload/ok.html");  
  51. }  
  52. }  
  53. }  
  54. } catch (Exception e) {  
  55. e.printStackTrace();  
  56. }  
  57. }  
  58. }  

 自学的软件工程的设计思路

Ø 定义阶段:可行性研究初步项目计划、需求分析

网上商城的目的是为广大的网络用户提供一个网上购物平台,利用网络的便捷方便人们的日常生活。为了使它适合更多的用户使用,系统的界面设计应该尽量做到友好、简洁,功能的实现更注重人性化,方便用户的购买,使得用户很快便可以熟练掌握使用方法。

本系统采用B/S模式,服务器端使用JSP进行动态网页的开发。

Ø 开发阶段:概要设计详细设计、实现、测试

网上商城可以为各类用户提供方便的在线购物环境。用户可以在系统中实现 注册、浏览商品、下订单、处理订单等功能;管理员可以通过用户管理、订单管理、商品管理等管理功能来对系统进行维护更新。

Ø 运行和维护阶段:运行、维护、废弃

网上商城分为前台用户界面和后台管理系统。所以要对商城的运行效率和稳定性进行测试。提高系统的安全性和稳定性。

活动图:

商城前台活动图

后台管理系统活动图

演示: 网上商城客户端

浏览商品

购买商品

后台管理系统:

上传图片,然后保存图片路径到数据库

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • iCDO一周数据要闻:苹果将下调日本iPhone XR价格;Ins将使用机器学习打击买粉买赞;5G云服务市场规模达4100亿美元

    11月21日 亚马逊欲在线下普及Amazon Pay,挑战苹果Apple Pay

    iCDO互联网数据官
  • 支付系统

    支付系统是连接消费者、商家(或平台)和金融机构的桥梁,管理支付数据,调用第三方支付平台接口,记录支付信息(对应订单号,支付金额等),金额对账等功能,根据不同公司...

    纯洁的微笑
  • 瓜子严选店遍地开花,背后是庞大的二手车AI生态

    11月23日,瓜子二手车严选直卖店在重庆正式开业,罗超频道(微信ID:luochaotmt)受邀到现场参加开业典礼。该店面积达到3万平方米,可以容纳800辆车展...

    罗超频道
  • “独立”评测自媒体,为何就成了一门简单粗暴的生意?

    12月3日,新榜上一则微信公众平台内测“洗稿投诉合议小组”,协助平台对有争议的“洗稿”内容进行合议的消息引起了自媒体圈的注意。按照已知的消息,如果用户接受邀请,...

    曾响铃
  • OTT变革进入“深水区”,看酷开系统7.0如何搅动“新硬件”蓝海

    近几年,在移动互联网的冲击之下,彩电行业一直处在焦虑状态。但在“AI+IOT”时代趋势的加持之下,作为未来客厅经济的主角——互联网电视反倒呈现出一片勃勃生机。

    曾响铃
  • 三大门户二十年,中国互联网踏上新征程

    12月1日,是新浪20岁生日,新浪众多官方账号在微博发起了#新浪20周年#的转发抽奖活动,随机抽取网友,每人1万元感恩现金。12月2日,新浪董事长兼CEO、微博...

    罗超频道
  • 从消费互联网到产业互联网,互联网行业发生了哪些变化

    马化腾在知乎的发问,一举将产品互联网的概念推上全民热论的高潮,伴随着话题不断升温,媒体焦点、融资方向、市场需求都开始向TO B企业偏转,TO B 成为资本追逐的...

    齿轮易创说互联网
  • 【首次公开】京东智能供应链首席科学家申作军的创新理念:端对端做库存管理

    “尽量让决策链变得短。能够一步做的决策,不要分两步,一方面人员减少,另一方面精度会提高,即用端对端的方法来做库存管理。在我们供应链领域没人做过这方面的研究,这是...

    京东技术
  • 京东荣获科促会科技产业化特等奖 无界零售已成传统产业升级利器

    当前,全球的线下零售业态主要以传统的进销渠道为主,部分品类的区域特征较为明显,总体来看互联网IT服务与信息技术的使用渗透率不高。京东作为实体经济与数字经济深度融...

    京东技术
  • 马云的野路子,只属于阿里的新零售

    马云的路子野在于它能够抓住每一次新风口萌芽的时机,并且能够真正将他对于未来的想象落地。有一个事情我们需要特别明白,那就是当马云在云栖大会上提出新零售概念的时候,...

    孟永辉

扫码关注云+社区

领取腾讯云代金券