JavaWeb网上商城的设计

不知道从什么时候起,我爱上了写博客,对之前学得的只是进行反思。写了几天课程设计,代码量量89千左右。

然后下面文字是我在博客上复制过来的,说得很详细

MVC(ModelViewController)设计模式在JavaFX中有着比Swing更好的表现方式。它使得程序界面设计和程序逻辑设计完全分开,便于代码的可读性和以后的可维护性。

JavaEE体系架构采用传统的MVC设计模式,分为Model、View、Controller三层,其中:Model即模型层,定义数据模型和业务逻辑。为了将数据访问与业务逻辑分离,提高业务精度,降低代码之间的耦合,模型层又细分为DAO层与业务层,DAO全称为DataAccessObject(数据访问对象),将数据库访问代码封闭起来,HibernateAPI也在此封装,不再出现在其他层或向其他层暴露;业务层是整个系统最核心也最具价值的一层,该层封装应用程序的业务逻辑,处理数据,关注客户需求,在业务处理过程中会访问原始数据或产生新数据,或者需要持久化数据,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]viewplaincopy

  1. <%@pagelanguage="java"import="java.util.*"pageEncoding="utf-8"%>
  2. <%
  3. Stringpath=request.getContextPath();
  4. StringbasePath=request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
  5. %>
  6. <!DOCTYPEHTMLPUBLIC"-//W3C//DTDHTML4.01Transitional//EN">
  7. <html>
  8. <head>
  9. <basehref="<%=basePath%>">
  10. <title>MyJSP'upload.jsp'startingpage</title>
  11. <metahttp-equiv="pragma"content="no-cache">
  12. <metahttp-equiv="cache-control"content="no-cache">
  13. <metahttp-equiv="expires"content="0">
  14. <metahttp-equiv="keywords"content="keyword1,keyword2,keyword3">
  15. <metahttp-equiv="description"content="Thisismypage">
  16. <!--
  17. <linkrel="stylesheet"type="text/css"href="styles.css">
  18. -->
  19. </head>
  20. <body>
  21. <formaction="/upload/UpLoad"method="post"enctype="multipart/form-data">
  22. 请选择上传的图片或文件:<inputtype="file"name="fileName"/><inputtype="submit"value="上传"/>
  23. </form>
  24. </body>
  25. </html>

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

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

[java]viewplaincopy

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

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

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

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

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

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

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

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

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


活动图:

商城前台活动图



后台管理系统活动图





演示:

网上商城客户端



浏览商品


购买商品

后台管理系统:

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







  • 0
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值