JavaWeb网上商城的设计
不知道从什么时候起,我爱上了写博客,对之前学得的只是进行反思。写了几天课程设计,基本功能实现了
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
- <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
- <%
- String path = request.getContextPath();
- String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
- %>
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
- <html>
- <head>
- <base href="<%=basePath%>">
- <title>My JSP 'upload.jsp' starting page</title>
- <meta http-equiv="pragma" content="no-cache">
- <meta http-equiv="cache-control" content="no-cache">
- <meta http-equiv="expires" content="0">
- <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
- <meta http-equiv="description" content="This is my page">
- <!--
- <link rel="stylesheet" type="text/css" href="styles.css">
- -->
- </head>
- <body>
- <form action="/upload/UpLoad" method="post" enctype="multipart/form-data">
- 请选择上传的图片或文件:<input type="file" name="fileName"/><input type="submit" value="上传"/>
- </form>
- </body>
- </html>
可以看到,我们将数据提交到工程下的upload/UpLoad。
之后,我们就来编写这个servlet——UpLoad.java
[java] view plaincopy
- package load;
- import java.io.File;
- import java.io.IOException;
- import java.io.PrintWriter;
- import java.util.List;
- import javax.servlet.ServletContext;
- import javax.servlet.ServletException;
- import javax.servlet.http.HttpServlet;
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpServletResponse;
- import org.apache.commons.fileupload.FileItem;
- import org.apache.commons.fileupload.FileUploadException;
- import org.apache.commons.fileupload.disk.DiskFileItemFactory;
- import org.apache.commons.fileupload.servlet.ServletFileUpload;
- public class UpLoad extends HttpServlet {
- @SuppressWarnings("unchecked")
- @Override
- protected void service(HttpServletRequest req, HttpServletResponse resp)
- throws ServletException, IOException {
- req.setCharacterEncoding("utf-8");
- resp.setContentType("text/html;charset=utf-8");
- //为解析类提供配置信息
- DiskFileItemFactory factory = new DiskFileItemFactory();
- //创建解析类的实例
- ServletFileUpload sfu = new ServletFileUpload(factory);
- //开始解析
- sfu.setFileSizeMax(1024*400);
- //每个表单域中数据会封装到一个对应的FileItem对象上
- try {
- List<FileItem> items = sfu.parseRequest(req);
- //区分表单域
- for (int i = 0; i < items.size(); i++) {
- FileItem item = items.get(i);
- //isFormField为true,表示这不是文件上传表单域
- if(!item.isFormField()){
- ServletContext sctx = getServletContext();
- //获得存放文件的物理路径
- //upload下的某个文件夹 得到当前在线的用户 找到对应的文件夹
- String path = sctx.getRealPath("/upload");
- System.out.println(path);
- //获得文件名
- String fileName = item.getName();
- System.out.println(fileName);
- //该方法在某些平台(操作系统),会返回路径+文件名
- fileName = fileName.substring(fileName.lastIndexOf("/")+1);
- File file = new File(path+"\\"+fileName);
- if(!file.exists()){
- item.write(file);
- //将上传图片的名字记录到数据库中
- resp.sendRedirect("/upload/ok.html");
- }
- }
- }
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- }
自学的软件工程的设计思路
Ø 定义阶段:可行性研究初步项目计划、需求分析
网上商城的目的是为广大的网络用户提供一个网上购物平台,利用网络的便捷方便人们的日常生活。为了使它适合更多的用户使用,系统的界面设计应该尽量做到友好、简洁,功能的实现更注重人性化,方便用户的购买,使得用户很快便可以熟练掌握使用方法。
本系统采用B/S模式,服务器端使用JSP进行动态网页的开发。
Ø 开发阶段:概要设计、详细设计、实现、测试
网上商城可以为各类用户提供方便的在线购物环境。用户可以在系统中实现 注册、浏览商品、下订单、处理订单等功能;管理员可以通过用户管理、订单管理、商品管理等管理功能来对系统进行维护更新。
Ø 运行和维护阶段:运行、维护、废弃
网上商城分为前台用户界面和后台管理系统。所以要对商城的运行效率和稳定性进行测试。提高系统的安全性和稳定性。
活动图:
商城前台活动图
后台管理系统活动图
演示:
网上商城客户端
浏览商品
购买商品
后台管理系统:
上传图片,然后保存图片路径到数据库
ps:本系统只是一个课程设计,是博主大二时候做的,功能很简单,只能学习参考。采用的技术栈是Servlet+jsp,并没有用框架
技术博客专栏学习:
- java框架文集
- Mysql系列文集
部分技术博客参考学习:
- SpringMVC+Mybatis整合教程
- Web系统之百度富文本编辑器使用
微信打赏
技术博客公众号
QQ群:1129337987
JavaWeb网上商城的设计相关推荐
- 基于JavaScript网上商城开发设计 毕业设计-附源码261620
Node.js网上商城的开发 摘 要 随着Internet的使用越来越广泛,在传统的商业模式中,对于日常各类商品,人们习惯于到各种商家店铺购买.然而在快节奏的新时代中,人们不一定能为购买各类商品腾出 ...
- 基于php办公用品网上商城的设计与实现(含源文件)
欢迎添加微信互相交流学习哦! 项目源码:https://gitee.com/oklongmm/biye 题 目 办公用品网上商城的设计与实现 摘 要 办公用品是人们日常生活中必不可少的 ...
- HTML5期末大作业:电商网站设计——粉色的鲜花礼品电商(4页) HTML+CSS+JavaScript 学生网上商城网页设计作业成品 web课程设计网页规划与设计 计算机毕设网页设计源码
HTML5期末大作业:电商网站设计--粉色的鲜花礼品电商(4页) HTML+CSS+JavaScript 学生网上商城网页设计作业成品 web课程设计网页规划与设计 计算机毕设网页设计源码 常见网页设 ...
- python制作购物网站开题报告_网上商城的设计与实现开题报告
篇一:网上购物系统的开题报告 本科毕业论文(设计)开题报告 论 文 题 目: 网上购物系统的实现 学 院: 专 业 .班 级:计算机科学与技术 学 生 姓 名: 指导教师(职称): 2013年 **月 ...
- php mysql 网站 任务书_办公用品网上商城的设计与实现PHP+MYSQL任务书
办公用品网上商城的设计与实现PHP+MYSQL任务书 毕业设计(论文)任务书 题 目 办公用品网上商城的设计与实现 起讫日期 2013年 3月 25 日 至 2013年 6 月28 日 学生姓名 专业 ...
- Online Shopping网上商城数据库设计
本系统是我通过自学课程中了解网上商城的基本业务逻辑和经营过程而开发的一个网上商城的网站,按照我的惯例,对于比较大型的系统,我一般都是把数据库单独举出来,因为数据库设计的好坏,直接影响到后期后台代码和业 ...
- 软件工程-网上商城分析设计(小组项目)
网上商城 网上商城需求分析 网上商城的主要参与者有会员,以及管理人员.此外,访客(非会员)也可是使用该系统进行一些商品的查询等. 另外,为了业务发展和内部管理分工明确,商城希望按照工作范围分配管理员的 ...
- [内附完整源码和文档] 基于SSH网上商城的设计与实现
摘 要 本文讲述了基于SSH框架的网上商城购物系统的设计与实现.所谓的网上商城购物系统是通过网站推广互联企业的商品和技术服务,并使客户随时可以了解企业和企业的产品,为客户提供在线服务和订单处理功能. ...
- JavaWeb网上商城
web项目1.关于web项目目的:将web阶段所有学过的知识点复习总结.2.关于web项目功能:功能: 1.用户注册2.用户登录3.添加商品(上传)4.商品查看-- 列表查询5.商品详情页面6.将商品 ...
最新文章
- [CTSC2018]混合果汁
- 有序数组中查找数字的范围
- ASP.NET MVC Training Kit发布了
- Python模块: 命令行解析optionparser
- [development][profile][dpdk] KK程序性能调优
- 使用@Autowired注解警告Field injection is not recommended
- Python对json数据的操作(香烟示例)
- Java 什么是静态内部类
- tensorflow之max_pool
- 阿里云ECS服务器Linux-ubuntu18环境搭建
- [杂谈]金克木:《与小说对话:不败求败》
- 学生指导——学习心理
- java操作word文档(文字,图片,表格添加以及替换操作)
- 大学里的网络安全专业为什么没多少人就读?
- Retrying connect to server: xxx.xxx.xxx.xxx:8032. Already tried 0 time(s)
- snprintf函数的用法详解
- 蓝牙耳机主动降噪的基础知识介绍
- C#/VB.NET 自定义PPT动画路径
- 三层交换机和二层交换机之间的配置
- html设置一个正方形渐变,CSS3 渐变
热门文章
- oracle查询某个用户下所有表记录总数
- 计算机开机界面图片怎么修改,怎么修改Win7开机登录界面壁纸 Win7开机登录界面壁纸修改图文教程...
- ntpd、ntpdate的区别
- 什么是Web应用防火墙
- 排行前50的编程语言
- 数据分析系列学习之My SQL(一)初识My SQL
- PS简单操作快捷键,上手快
- [JavaWeb实训Day3]__button_框架布局点击事件
- vue UI(Vertify和Element)优缺点随录
- H.266/VVC相关技术学习笔记16:VTM6.0中的CIIP技术(帧内帧间联合预测)