目 录
随着科学技术的飞速发展,社会的方方面面、各行各业都在努力与现代的先进技术接轨,通过科技手段来提高自身的优势,商品比价软件APP当然也不能排除在外。商品比价软件APP是以实际运用为开发背景,运用软件工程开发方法,采用Java技术构建的一个管理系统。整个开发过程首先对软件系统进行需求分析,得出系统的主要功能。接着对系统进行总体设计和详细设计。总体设计主要包括系统总体结构设计、系统数据结构设计、系统功能设计和系统安全设计等:详细设计主要包括模块实现的关键代码,系统数据库访问和主要功能模块的具体实现等。最后对系统进行功能测试,并对测试结果进行分析总结,及时改进系统中存在的不足,为以后的系统维护提供了方便,也为今后开发类似系统提供了借鉴和帮助。
本商品比价软件APP采用的数据库是Mysql,使用JAVA技术开发。在设计过程中,充分保证了系统代码的良好可读性、实用性、易扩展性、通用性、便于后期维护、操作方便以及页面简洁等特点。
关键词:Java技术;MYSQL;商品比价软件APP
Abstract
With the rapid development of science and technology, all aspects of society and all walks of life are striving to integrate with modern advanced technology and improve their advantages through scientific and technological means. Of course, commodity price comparison software APP cannot be excluded. The commodity price comparison software APP is a management system built based on practical application, using software engineering development methods, and Java technology. The entire development process begins with a requirements analysis of the software system to obtain the main functions of the system. Then, the overall design and detailed design of the system are carried out. The overall design mainly includes the overall system structure design, system data structure design, system function design, and system security design. The detailed design mainly includes the key code for module implementation, system database access, and the specific implementation of the main functional modules. Finally, a functional test of the system was conducted, and the test results were analyzed and summarized to timely improve the shortcomings of the system, providing convenience for future system maintenance and providing reference and assistance for the development of similar systems in the future.
The database used in this commodity price comparison software APP is MySQL, developed using JAVA technology. During the design process, the system code has been fully guaranteed to have good readability, practicality, scalability, versatility, ease of later maintenance, easy operation, and concise pages.
Keywords:Java technology; MYSQL;Commodity price comparison software APP
1 绪论
1.1 开发背景
互联网是人类的基本需求,特别是在现代社会,个人压力增大,社会运作节奏高,随着互联网的快速发展,用户的需求也越来越高,用户也将越来越多依靠互联网而不是自己获取信息,使得各种软件程序的开发得到了应用。
近年来,随着我国经济的不断发展,平台的管理制度越来越多。每个商品比价软件APP也都将通过计算机进行整体智能化操作,对于商品比价软件APP功能所牵扯的数据都是通过用户进行商品比价软件APP等相关的数据信息内容、并且可以进行管理员后端:商品比价、商品分类、系统用户、资源管理、商城管理,用户前端首页、购物车、商品资讯、我的等功能可以通过系统进行分配,传统的手工统计模式已经无法满足用户的需求。为此开发了本商品比价软件APP,为用户提供一个基于ssm商品比价软件APP,同时方便管理员对用户信息进行操作。该系统满足了用户对商品比价软件APP信息获取的需求,并且信息可以及时、准确、有效地进行查看并且系统化、标准化和有效的工作。
1.2研究现状
随着社会的发展和科学技术的进步,互联网技术越来越受欢迎。网络传播的生活方式逐渐受到广大人民群众的喜爱。越来越多的互联网爱好者开始在互联网上满足他们的基本需求,同时逐渐进入各个用户的生活起居。互联网具有许多优点,例如便利性,速度,高效率和低成本。因此,类似于基于安卓app的商品比价软件,满足用户工作繁忙的需求,不仅是方便用户随时查看信息的途径,而且还能提高管理效率。
本文首先以基于安卓app的商品比价软件过程的基本问题作为研究对象。在开发系统之前,我们对现有状况进行了详细的调查和分析。最后,我们利用计算机技术开发了一套完整合适的基于安卓app的商品比价软件。该系统的实现主要优势是:该系统主要采用计算机技术开发,它方便快捷;系统可以通过管理员界面查看用户的所有信息管理。
基于安卓app的商品比价软件软件是一款方便、快捷、实用的信息服务查询软件。随着智能网络在全球市场的不断普及以及各种智能平台的使用,系统的开发与人们的日常需求相关,作为中国主流智能的技术开发系统,自然需要这样的软件来满足更多用户的需求和体验。
1.3论文结构与章节安排
论文将分层次经行编排,除去论文摘要致谢文献参考部分,正文部分还会对网站需求做出分析,以及阐述大体的设计和实现的功能,最后罗列部分调测记录,论文主要架构如下:
第一章:引言。第一章主要介绍了课题研究的背景,系统开发的现状和本文的研究内容与主要工作。
第二章:系统需求分析。第二章主要从系统的用户、功能等方面进行需求分析。
第三章:系统设计。第三章主要对系统框架、系统功能模块、数据库进行功能设计。
第四章:系统实现。第四章主要介绍了系统框架搭建、系统界面的实现。
第五章:系统测试。第五章主要对系统的部分界面进行测试并对主要功能进行测试
系统分析是开发一个项目的先决条件,通过系统分析可以很好的了解系统的主体用户的基本需求情况,同时这也是项目的开发的原因。进而对系统开发进行可行性分析,通常包括技术可行性、经济可行性等,可行性分析同时也是从项目整体角度进行的分析。然后就是对项目的具体需求进行分析,分析的手段一般都是通过用户的用例图来实现。下面是详细的介绍。
2.1 可行性分析
经济可行性在此仅代表网站的运维成本,开发成本不在此考虑。
目前该模式下的商品比价软件APP的数量日益增多,网购变得平民化普及化用户人数呈上升趋势,当用户人数庞大了,运维成本可以由广告费进行填补,包括开发成本。
所以经济可行性没有问题。
(2)操作可行性:
此次项目设计参考了几个该模式下网站的开发案例,对他们的操作界面分析,将众多案例结合在一起,突出以人为本简化操作,所以具有基本计算机知识的人都会操作本项目。
因此操作可行性也没有问题。
(3)技术可行性:
技术可行性指的是对于搭建框架的可行性,以及有更优秀的技术出现时系统的技术更新换代的纳新性如何,开发时间成本费用比如何。
现有的ssm技术能够迎合所有电子商务系统的搭建。开发这个商品比价软件APP 的时候我采用了ssm+MYSQL用以运行整体程序。
综上所述技术可行性也没有问题。
(4)法律可行性:
从开发者角度来看,ssm和MYSQL是网上开源且免费的,在知识产权方面不会产生任何法律纠纷。
从用户使用角度来看,只要不再系统上贩卖违禁品,对系统做出条约协议,杜绝非法支付即可。
综上所述法律可行性也没有问题。
2.2.1 数据流程
商品比价软件APP主要的目的就是实现对商品的在线选购,图2-1就是系统的数据流图。

图2-1商品购买操作展开图
3.3.2 业务流程
分析完系统的数据流,接下来我们来看系统的业务流程,图2-2就是业务流程图:

图2-2业务流程图
按照商品比价软件APP的角色,我划分为了会员用户管理模块和管理员管理模块这两大部分。
会员用户管理模块:
(1)用户注册登录:用户注册为用户并登录商品比价软件APP ;用户对个人信息的增删改查,比如个人资料,密码修改。
(2)用户查看商品:用户进行商品信息的阅览,通过发现喜欢的商品后可以购买+评论+收藏。
(3)商品资讯:用户进行资讯的阅览,查看管理者发布的商品资讯信息。
(5)商品购买:用户对喜欢的商品可以加购,在购物车里面,当用户确定提交完毕后,将其提交给服务器后台系统,并生成订单。
(6)我的订单:用户在提交订单后,可以对提交的订单进行管理。
管理员管理模块:
(1)系统用户:管理员可以对前台上注册过的会员用户信息进行管控,也可以对管理员信息进行管控。
(2)资源管理:管理员可以对商品比价软件APP前台展示的商品资讯以及资讯分类所属的分类进行管控。
(3)分类管理:管理员对商品比价软件APP 中商品的分类进行管控。
(4)商城管理:管理员对用户提交的商品信息进行管控。
(5)轮播图管理:管理员可以对商品比价软件APP中首页显示的轮播图发布到系统当中,让用户及时的查看到轮播图信息,进行合理安排。
(6)模块管理:在“模块管理”这一菜单下可以对系统当中的用户操作的所有信息进行管理,包含了商品比价、商品分类。
商品比价软件APP的非功能性需求比如商品比价软件APP的安全性怎么样,可靠性怎么样,性能怎么样,可拓展性怎么样等。具体可以表示在如下3-1表格中:
表3-1商品比价软件APP非功能需求表
安全性 |
主要指商品比价软件APP数据库的安装,数据库的使用和密码的设定必须合乎规范。 |
可靠性 |
可靠性是指商品比价软件APP 能够安装用户的指示进行操作,经过测试,可靠性90%以上。 |
性能 |
性能是影响商品比价软件APP 占据市场的必要条件,所以性能最好要佳才好。 |
可扩展性 |
比如数据库预留多个属性,比如接口的使用等确保了系统的非功能性需求。 |
易用性 |
用户只要跟着商品比价软件APP 的页面展示内容进行操作,就可以了。 |
可维护性 |
商品比价软件APP 开发的可维护性是非常重要的,经过测试,可维护性没有问题 |
2.4 系统用例分析
通过2.3功能的分析,得出了本商品比价软件APP的用例图:
会员用户角色用例如图2-3所示。

图2-3 商品比价软件APP会员用户角色用例图
web后台管理上的管理员是维护整个商品比价软件APP中所有数据信息的。管理员角色用例如图2-4所示。

本章主要通过对商品比价软件APP的可行性分析、流程分析、功能需求分析、系统用例分析,确定整个商品比价软件APP要实现的功能。同时也为商品比价软件APP的代码实现和测试提供了标准。
本章主要讨论的内容包括商品比价软件APP的功能模块设计、数据库系统设计。
3.1 系统架构设计
本商品比价软件APP 从架构上分为三层:表现层(UI)、业务逻辑层(BLL)以及数据层(DL)。

图3-1商品比价软件APP 系统架构设计图
表现层(UI):又称UI层,主要完成本商品比价软件APP的UI交互功能,一个良好的UI可以打打提高用户的用户体验,增强用户使用本商品比价软件APP时的舒适度。UI的界面设计也要适应不同版本的商品比价软件APP以及不同尺寸的分辨率,以做到良好的兼容性。UI交互功能要求合理,用户进行交互操作时必须要得到与之相符的交互结果,这就要求表现层要与业务逻辑层进行良好的对接。
业务逻辑层(BLL):主要完成本商品比价软件APP的数据处理功能。用户从表现层传输过来的数据经过业务逻辑层进行处理交付给数据层,系统从数据层读取的数据经过业务逻辑层进行处理交付给表现层。
数据层(DL):由于本商品比价软件APP的数据是放在服务端的mysql数据库中,因此本属于服务层的部分可以直接整合在业务逻辑层中,所以数据层中只有数据库,其主要完成本商品比价软件APP 的数据存储和管理功能。
3.2 系统功能模块设计
在上一章节中主要对系统的功能性需求和非功能性需求进行分析,并且根据需求分析了本商品比价软件APP中的用例。那么接下来就要开始对本商品比价软件APP的架构、主要功能和数据库开始进行设计。商品比价软件APP根据前面章节的需求分析得出,其总体设计模块图如图3-2所示。

图3-2 商品比价软件APP功能模块图
3.2.2用户模块设计
后台管理者能够实现对前台注册的用户增删改查操作,用户模块结构图如下图:

图3-3用户用户模块结构图
3.2.3 评论管理模块设计
商品比价软件APP 是一个交流性质的公开平台,用户用户可以在平台上交流,增加用户之间的互动性。但是同时也为了更好的规范评论的内容,给予管理员删除不合适的言论的功能,所以需要专门设计一个评论管理模块,具体的结构图如下:

图3-4评论模块结构图
3.2.4商城管理模块设计
商品比价软件APP是中需要存储不少商品信息,其模块功能结构,具体的结构图如下:

图3-5商城模块结构图
3.2.5订单管理模块设计
商品比价软件APP最重要的一个功能就是购买,其模块功能结构,具体的结构图如下:

图3-5订单模块结构图
数据库设计一般包括需求分析、概念模型设计、数据库表建立三大过程,其中需求分析前面章节已经阐述,概念模型设计有概念模型和逻辑结构设计两部分。
3.3.1 数据库概念结构设计
下面是整个商品比价软件APP中主要的数据库表总E-R实体关系图。
图3-6 商品比价软件APP 总E-R关系图
下面根据商品比价软件APP 的数据库总E-R关系图可以得出商品比价软件APP 需要很多E-R图,在此罗列出来一些主要的数据库E-R模型图。

图3-7会员用户E-R关系图

图3-8 订单信息E-R关系图

图3-9 地址信息E-R关系图
通过上一小节中商品比价软件APP 中总E-R关系图上得出一共需要创建很多个数据表。在此我主要罗列几个主要的数据库表结构设计。
表address (收货地址:)
编号 |
名称 |
数据类型 |
长度 |
小数位 |
允许空值 |
主键 |
默认值 |
说明 |
1 |
address_id |
int |
10 |
0 |
N |
Y |
收货地址: |
|
2 |
name |
varchar |
32 |
0 |
Y |
N |
姓名: |
|
3 |
phone |
varchar |
13 |
0 |
Y |
N |
手机: |
|
4 |
postcode |
varchar |
8 |
0 |
Y |
N |
邮编: |
|
5 |
address |
varchar |
255 |
0 |
N |
N |
地址: |
|
6 |
user_id |
mediumint |
8 |
0 |
N |
N |
用户ID:[0,8388607]用户获取其他与用户相关的数据 |
|
7 |
create_time |
timestamp |
19 |
0 |
N |
N |
CURRENT_TIMESTAMP |
创建时间: |
8 |
update_time |
timestamp |
19 |
0 |
N |
N |
CURRENT_TIMESTAMP |
更新时间: |
9 |
default |
bit |
1 |
0 |
N |
N |
0 |
默认判断 |
表article (文章:用于内容管理系统的文章)
编号 |
名称 |
数据类型 |
长度 |
小数位 |
允许空值 |
主键 |
默认值 |
说明 |
1 |
article_id |
mediumint |
8 |
0 |
N |
Y |
文章id:[0,8388607] |
|
2 |
title |
varchar |
125 |
0 |
N |
Y |
标题:[0,125]用于文章和html的title标签中 |
|
3 |
type |
varchar |
64 |
0 |
N |
N |
0 |
文章分类:[0,1000]用来搜索指定类型的文章 |
4 |
hits |
int |
10 |
0 |
N |
N |
0 |
点击数:[0,1000000000]访问这篇文章的人次 |
5 |
praise_len |
int |
10 |
0 |
N |
N |
0 |
点赞数 |
6 |
create_time |
timestamp |
19 |
0 |
N |
N |
CURRENT_TIMESTAMP |
创建时间: |
7 |
update_time |
timestamp |
19 |
0 |
N |
N |
CURRENT_TIMESTAMP |
更新时间: |
8 |
source |
varchar |
255 |
0 |
Y |
N |
来源:[0,255]文章的出处 |
|
9 |
url |
varchar |
255 |
0 |
Y |
N |
来源地址:[0,255]用于跳转到发布该文章的网站 |
|
10 |
tag |
varchar |
255 |
0 |
Y |
N |
标签:[0,255]用于标注文章所属相关内容,多个标签用空格隔开 |
|
11 |
content |
longtext |
2147483647 |
0 |
Y |
N |
正文:文章的主体内容 |
|
12 |
img |
varchar |
255 |
0 |
Y |
N |
封面图 |
|
13 |
description |
text |
65535 |
0 |
Y |
N |
文章描述 |
表article_type (文章分类)
编号 |
名称 |
数据类型 |
长度 |
小数位 |
允许空值 |
主键 |
默认值 |
说明 |
1 |
type_id |
smallint |
5 |
0 |
N |
Y |
分类ID:[0,10000] |
|
2 |
display |
smallint |
5 |
0 |
N |
N |
100 |
显示顺序:[0,1000]决定分类显示的先后顺序 |
3 |
name |
varchar |
16 |
0 |
N |
N |