Bootstrap

SSM酒店点餐系统 毕业设计源码65930

                                                                        摘  要

随着互联网趋势的到来,各行各业都在考虑利用互联网将自己推广出去,最好方式就是建立自己的互联网系统,并对其进行维护和管理。在现实运用中,应用软件的工作规则和开发步骤,采用Java技术建设酒店点餐系统。

本设计主要实现集人性化、高效率、便捷等优点于一身的酒店点餐系统,完成用户管理、个人资料、菜品分类、点餐菜谱、订单中心、营业额、餐厅餐桌、预定餐桌等功能模块。系统通过浏览器与服务器进行通信,实现数据的交互与变更。只需通过一台电脑,动动手指就可以操作系统,实现数据通信管理。整个系统的设计过程都充分考虑了数据的安全、稳定及可靠等问题,而且操作过程简单。本系统通过科学的管理方式、便捷的服务提高了工作效率,减少了数据存储上的错误和遗漏。

酒店点餐系统使用Java语言,采用基于MVVM模式的JavaEE技术进行开发,使用 MyEclipse 2017 CI 10 编译器编写,数据方面主要采用的是微软的MySQL关系型数据库来作为数据存储媒介,配合前台HTML+CSS 技术完成系统的开发。

关键词:酒店点餐系统 ;Java;SSM;MYSQL

                                                            Abstract

With the advent of the Internet trend, all walks of life are considering using the Internet to promote themselves. The best way is to establish their own Internet system, and maintain and manage it. In practical application, the working rules and development steps of the application software are used to build the hotel order system using Java technology.

This design mainly realizes the hotel order system integrating the advantages of humanization, efficiency and convenience, and completes user management, personal data, dish classification, order menu, order center, turnover, restaurant table, table reservation and other functional modules. The system communicates with the server through the browser to realize data interaction and change. You can operate the system by moving your fingers through a computer to realize data communication management. The design process of the whole system fully considers the safety, stability and reliability of data, and the operation process is simple. The system improves work efficiency and reduces errors and omissions in data storage through scientific management and convenient services.

The hotel meal ordering system uses Java language, adopts Java EE technology based on MVVM mode for development, and uses MyEclipse 2017 CI 10 compiler for compilation. In terms of data, it mainly uses Microsoft's MySQL relational database as the data storage medium, and cooperates with the foreground HTML+CSS technology to complete the system development.

Keywords: Hotel order system; Java; SSM; MYSQL

                                                         目录

1 绪论

1.1 目的及意义

1.2 开发现状

1.3 相关技术介绍

1.4 ssm框架介绍

2 酒店点餐系统分析

2.1 可行性分析

2.1.1 技术可行性分析

2.1.2 经济可行性分析

2.2 系统需求分析

2.2.1 功能性需求分析

2.2.2 非功能性分析

2.3 系统用例分析

3 酒店点餐系统 总体设计

3.1 系统模块设计

3.2 数据库设计

3.3.1 数据库概念结构设计

3.2.2 数据库逻辑结构设计

4 酒店点餐系统设计与实现

4.1 系统首页页面

4.2 注册页面

4.3 登录页面

4.4 酒店资讯页面

4.5点餐菜谱页面

4.6 修改密码页面

4.7 公共管理页面

4.8 用户管理页面

4.9 酒店资讯管理页面

4.10 订单中心管理页面

4.11 预定餐桌管理页面

5酒店点餐系统测试

5.1 调试部分问题

5.2 系统测试用例

5.3 系统测试结果

结论

参考文献

  

1 绪论

1.1 目的及意义

随着人们步入信息时代的脚步,餐饮行业从以往的全手工经营方式,到手工操作和计算机管理并存的半手工经营方式,最终步入了全信息化经营方式,一个好的酒店点餐系统不仅能帮助酒店节约成本,提高经营效率,还可极大地提高酒店的服务质量。作为目前餐饮管理规划的一部分,它集点菜、结帐、查询、统计、设置等各种功能为一体,对于提高餐饮管理效率、增加收入发挥不可替代的作用。酒店点菜管理系统主要包括了服务器端和客户端,通过计算机对菜单、点菜信息、收银及订位等进行操作和管理,全部实现智能化,不需要传统的服务员来记单,极大地提升了酒店的档次,方便了客户,同时也提高了酒店的效率。

1.2开发现状

市场上出现的酒店点餐系统都是作为餐厅信息化管理系统的一部分出现的,它们除了实现基本的酒店点餐系统功能外,为了便于客户及管理者的使用,还附加了许多其他功能,个人很难完成一个功能完善的点餐系统。而在电子点餐系统中,方便又快捷;另外,电子菜单与普通菜单相比有很多它的优点,比如普通菜单易脏,需要服务人员写,单据易丢,复杂的财务核算工作;而电子菜单方便快捷,点单灵活,不需要过多的服务人员等待客人点单,管理方便,点单取餐全自助,节省人力及时间。

从国内开发现状来看,在安全性和信息更新化方面存在有一定的不足,各现有系统资料单独建立,共享性差;在以管理者为主体的方式中,信息取舍依赖管理者对于信息的认知与喜好,较不容易掌握用户真正的需求,也因此无法完全满足用户的需求。因此,餐厅点单系统应充分依托人客户量大的集中区域,实现点餐信息的集中管理、分散操作、信息共享,使传统的餐厅点单系统朝数字化、智能化、综合化的方向发展,并为进一步实现完善的餐厅点餐打下良好的基础,从技术角度,也会不断更新,优化出适合餐厅点单系统的框架,以便后续开发。

1.3相关技术介绍

(1)酒店点餐系统 中的web后台管理中的后端不再使用古老的jsp+javabean+servlet技术,而是使用当前主流的SSM框架,它减少java配置代码,简化编程代码,目前SSM框架也是很多企业选择的框架之一。

(2)酒店点餐系统 中的web后台管理中的前端使用的是bootstrap框架,它配合ajax和jquery可以美化页面设计。

(3)流行vue框架结合jQuery技术,在jQuery基础上扩展一些插件,通过自己定义插件更好的实现前端的设计。

(4)酒店点餐系统 中数据库用的mysql5.7,它执行效率高。

1.4ssm框架介绍:

SSM(Spring+SpringMVC+MyBatis)框架集由Spring、MyBatis两个开源框架整合而成(SpringMVC是Spring中的部分内容)。常作为数据源较简单的web项目的框架。

1.8.1 Spring
Spring就像是整个项目中装配bean的大工厂,在配置文件中可以指定使用特定的参数去调用实体类的构造方法来实例化对象。也可以称之为项目中的粘合剂。
Spring的核心思想是IoC(控制反转),即不再需要程序员去显式地`new`一个对象,而是让Spring框架帮你来完成这一切。
1.8.2 SpringMVC
SpringMVC在项目中拦截用户请求,它的核心Servlet即DispatcherServlet承担中介或是前台这样的职责,将用户请求通过HandlerMapping去匹配Controller,Controller就是具体对应请求所执行的操作。SpringMVC相当于SSH框架中struts。
1.8.3 mybatis
mybatis是对jdbc的封装,它让数据库底层操作变的透明。mybatis的操作都是围绕一个sqlSessionFactory实例展开的。mybatis通过配置文件关联到各实体类的Mapper文件,Mapper文件中配置了每个类对数据库所需进行的sql语句映射。在每次与数据库交互时,通过sqlSessionFactory拿到一个sqlSession,再执行sql命令。

页面发送请求给控制器,控制器调用业务层处理逻辑,逻辑层向持久层发送请求,持久层与数据库交互,后将结果返回给业务层,业务层将处理逻辑发送给控制器,控制器再调用视图展现数据。

2 酒店点餐系统 分析

2.1 可行性分析

2.1.1 技术可行性分析

通过了解对酒店点餐系统 的真实需求后,将酒店点餐系统 所需要的角色划分整理成了下图2-1,图2-2和图2-3。

从开发工具来看,由于酒店点餐系统 是基于JAVA的,因此有很多开发工具都可以进行开发,这些功能强大的开发工具可以给我来设计酒店点餐系统 带来非常大的方便。

从酒店点餐系统的本身技术来说,对于我来开发一个酒店点餐系统 这个毕设是不费事的。酒店点餐系统 的开发可以简单的分为前台端、后台端开发以及数据库开发。其中的大部分技术难点在我上学时已经使用过了,同时网络上很多技术点可以让我来借鉴。Web后台管理使用JAVA[9]的SSM架构开发,数据库使用mysql,页面上使用javascript脚本,因此为我在开发酒店点餐系统 这个毕设上省去了很多多余代码,这给我的毕设项目编写带来了极大的便利。综上所述,从技术层面来看开发酒店点餐系统 是可行的。

从用户体验来看,市面上很多被广泛使用的系统案例可以让我来参考,因此我可以综合它们的页面交互设计的优点,基于我的毕设项目特点来进行改版,最后达到令用户满意的页面交互体验。综上所述,从技术层面来看开发酒店点餐系统 是可行的。

2.1.2 经济可行性分析

酒店点餐系统的开发成本来看,酒店点餐系统的设计和开发都是我自己完成的,没有其他成本上的开销。

酒店点餐系统的维护成本来看,酒店点餐系统的开发遵循一套完整的代码编写规范,并且酒店点餐系统 的结构设计非常灵活,遵循高内聚低耦合的原则,因此易于维护和迭代开发。

酒店点餐系统上线之后,上线前期我会根据真实需求来调查,对使用我开发的酒店点餐系统来制定一套符合的使用费。系统运行稳定后我会将推广范围到其他的校园当中,其他校园可以使用我的酒店点餐系统,只需要缴纳一点点的定金,我会给他们引入广告投资和自营业务。

综合以上的分析,酒店点餐系统所带来的经济效益将会带来极大的收益。并且随着我的推广,来使用我开发的酒店点餐系统的市场将越来越大,酒店点餐系统带来的利润也就越来越多。因此,从经济层面来看开发酒店点餐系统的是可行的。

2.2 系统需求分析

2.2.1 功能性需求分析

酒店点餐系统从角色上划分为了注册用户、服务员以及管理员三种角色。

管理员用户角色:

(1)登录:管理员的账号是在数据表表中直接设置生成的,不需要进行注册;

(2)公共管理:当点击“公共管理”这一菜单的时候,会出现轮播图+酒店公告这两个子菜单,可以对这个模块进行增删改查操作;

(3)用户管理:当点击“用户管理”这一菜单的时候,会出现管理员+注册用户+服务员三个子菜单,可以对这个模块进行增删改查操作;

(4)信息管理:当点击“信息管理”这一菜单的时候,会出现酒店资讯+资讯分类个子菜单,可以对酒店资讯进行增删改查操作;

(5)点餐菜谱:管理员点击“点餐菜谱”会显示出所有的点餐菜谱,支持通过点餐菜谱状态或者输入菜品名称或者菜品类别点餐菜谱进行查询,如果想要添加新的点餐菜谱,点击“添加”按钮,输入相关信息,点击“提交”按钮就可以添加了,同时可以选择某一条点餐菜谱,点击“删除”进行删除也可以对用户提交的点餐菜谱评论的信息进行管控。

注册用户角色:

(1)注册登录模块:当注册用户想要进入本酒店点餐系统中对资讯进行查看评论以及了解点餐菜谱等操作的时候,就必须要登录到系统当中,要是新的用户没有酒店点餐系统的账号的话,点击“注册”按钮,就会进入到新用户注册这个界面上,用户输入对应的账号(必须填写)+密码(必须填写)+确认密码(必须填写,而且要与密码一直)+昵称+邮箱+手机号+选择用户身份等等,然后点击“注册”,系统在用户这一数据库中会查询账号是不是存在,两次密码是不是一样,都填写正确就会注册成功,然后再进行登录,如果是之前已经注册过的用户很长时间没有使用,忘记密码,也可以点击“忘记密码”进行找回;

(2)酒店资讯:在首页导航栏左侧我们会看到“酒店资讯”这一菜单,我们点击进入进去以后,会看到所有资讯列表,在这个界面,我们可以点击进入进行查看、评论、点赞等;

(3)酒店公告:在首页导航栏左侧我们会看到“酒店公告”这一菜单,我们点击进入进去以后,会看到所有管理员在后台发布的公告信息;

4)我的收藏:在“我的”下可以查看管理“我的收藏”信息,可以查看收藏,也可以对不喜欢的信息进行删除收藏;

5)我的账户:当用户点击右上角“我的”这个按钮,会出现子菜单,点击“我的账户”可以对个人的资料以及登录系统的密码进行设置;

6)个人中心:当用户点击右上角“我的”这个按钮,就会进入到对应的后台进行信息的管理了;

7)点餐菜谱用户可以查看点餐菜谱,在查询到自己想要了解的点餐菜谱的时候,可以进入查看详细的介绍,点击“下单”这一按钮以后会跳转到下单信息填写的界面,根据提示填写好下单的信息,点击“提交”以后下单就完成了,在点餐菜谱详情这个界面,同时支持用户对喜欢的点餐菜谱进行收藏、点赞评论的功能。

8)餐厅餐桌:用户可以查看餐厅餐桌信息支持通过搜索关键词的方式对餐厅餐桌进行查询,在查询到自己想要了解的餐厅餐桌的时候,可以进入查看详细的介绍。

2.2.2 非功能性分析

酒店点餐系统的非功能性需求比如酒店点餐系统 的安全性怎么样,可靠性怎么样,性能怎么样,可拓展性怎么样等。具体可以表示在如下2-1表格中:

2-1酒店点餐系统 非功能需求表

安全性

主要指酒店点餐系统 数据库的安装,数据库的使用和密码的设定必须合乎规范。

可靠性

可靠性是指酒店点餐系统 能够安装用户的指示进行操作,经过测试,可靠性90%以上。

性能

性能是影响酒店点餐系统 占据市场的必要条件,所以性能最好要佳才好。

可扩展性

比如数据库预留多个属性,比如接口的使用等确保了系统的非功能性需求。

易用性

用户只要跟着酒店点餐系统 页面展示内容进行操作,就可以了。

可维护性

酒店点餐系统 开发的可维护性是非常重要的,经过测试,可维护性没有问题

2.3 系统用例分析

根据上一节功能分析,可以得出系统的用例,注册用户角色用例如图2.1所示。

图2.1 酒店点餐系统中注册用户角色用例图

管理员角色用例如图2.2所示。

2.2 酒店点餐系统管理员角色用例图

3 酒店点餐系统总体设计

3.1 系统模块设计

根据第二章中酒店点餐系统的功能分析可知,酒店点餐系统 中整体功能模块图如图3.1所示, 

图3.1 酒店点餐系统功能模块图

3.2 数据库设计

3.3.1 数据库概念结构设计

下面是整个酒店点餐系统 中主要的数据库表总E-R实体关系图。

图3.2 酒店点餐系统 总E-R关系图

3.2.2 数据库逻辑结构设计

通过上一小节中酒店点餐系统 中总E-R关系图上得出一共需要创建很多个数据表。在此我主要罗列几个主要的数据库表结构设计。

表book_a_table (预订餐桌)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

book_a_table_id

int

10

0

N

Y

预订餐桌ID

2

table_type

varchar

64

0

Y

N

餐桌类型

3

seating_capacity

varchar

64

0

Y

N

可坐人数

4

user

int

10

0

Y

N

0

用户

5

number_of_diners

varchar

64

0

Y

N

就餐人数

6

meal_time

datetime

19

0

Y

N

就餐时间

7

full_name

varchar

64

0

Y

N

姓名

8

contact_number

varchar

64

0

Y

N

联系电话

9

reservation_remarks

varchar

64

0

Y

N

预订备注

10

examine_state

varchar

16

0

N

N

未审核

审核状态

11

examine_reply

varchar

16

0

Y

N

审核回复

12

recommend

int

10

0

N

N

0

智能推荐

13

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

14

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表categorization_of_dishes (菜品分类)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

categorization_of_dishes_id

int

10

0

N

Y

菜品分类ID

2

category_of_dishes

varchar

64

0

Y

N

菜品类别

3

recommend

int

10

0

N

N

0

智能推荐

4

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

5

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表collect (收藏)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

collect_id

int

10

0

N

Y

收藏ID

2

user_id

int

10

0

N

N

0

收藏人ID

3

source_table

varchar

255

0

Y

N

来源表

4

source_field

varchar

255

0

Y

N

来源字段

5

source_id

int

10

0

N

N

0

来源ID

6

title

varchar

255

0

Y

N

标题

7

img

varchar

255

0

Y

N

封面

8

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间

9

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表comment (评论)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

comment_id

int

10

0

N

Y

评论ID

2

user_id

int

10

0

N

N

0

评论人ID

3

reply_to_id

int

10

0

N

N

0

回复评论ID

4

content

longtext

2147483647

0

Y

N

内容

5

nickname

varchar

255

0

Y

N

昵称

6

avatar

varchar

255

0

Y

N

头像地址

7

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

9

source_table

varchar

255

0

Y

N

来源表

10

source_field

varchar

255

0

Y

N

来源字段

11

source_id

int

10

0

N

N

0

来源ID

表dining_table (餐厅餐桌)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

dining_table_id

int

10

0

N

Y

餐厅餐桌ID

2

table_type

varchar

64

0

Y

N

餐桌类型

3

picture

varchar

255

0

Y

N

图片

4

seating_capacity

int

10

0

Y

N

0

可坐人数

5

remarks

text

65535

0

Y

N

备注

6

hits

int

10

0

N

N

0

点击数

7

recommend

int

10

0

N

N

0

智能推荐

8

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

9

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表order_center (订单中心)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

order_center_id

int

10

0

N

Y

订单中心ID

2

order_number

varchar

64

0

Y

N

订单号

3

dish_no

varchar

64

0

Y

N

菜品编号

4

name_of_dishes

varchar

64

0

Y

N

菜品名称

5

category_of_dishes

varchar

64

0

Y

N

菜品类别

6

price

varchar

64

0

Y

N

价格

7

quantity

int

10

0

Y

N

0

数量

8

total_amount

varchar

64

0

Y

N

总金额

9

user

int

10

0

Y

N

0

用户

10

contact_number

varchar

64

0

Y

N

联系电话

11

table_number

varchar

64

0

Y

N

餐桌号

12

order_remarks

text

65535

0

Y

N

订单备注

13

pay_state

varchar

16

0

N

N

未支付

支付状态

14

pay_type

varchar

16

0

Y

N

支付类型: 微信、支付宝、网银

15

recommend

int

10

0

N

N

0

智能推荐

16

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

17

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表order_menu (点餐菜谱)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

order_menu_id

int

10

0

N

Y

点餐菜谱ID

2

dish_no

varchar

64

0

Y

N

菜品编号

3

name_of_dishes

varchar

64

0

Y

N

菜品名称

4

picture

varchar

255

0

Y

N

图片

5

category_of_dishes

varchar

64

0

Y

N

菜品类别

6

price

int

10

0

Y

N

0

价格

7

food_ingredients

varchar

64

0

Y

N

食材

8

dish_features

text

65535

0

Y

N

菜品特色

9

introduction_to_dishes

longtext

2147483647

0

Y

N

菜品介绍

10

hits

int

10

0

N

N

0

点击数

11

praise_len

int

10

0

N

N

0

点赞数

12

recommend

int

10

0

N

N

0

智能推荐

13

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

14

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表registered_users (注册用户)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

registered_users_id

int

10

0

N

Y

注册用户ID

2

gender

varchar

64

0

Y

N

性别

3

full_name

varchar

64

0

Y

N

姓名

4

examine_state

varchar

16

0

N

N

已通过

审核状态

5

recommend

int

10

0

N

N

0

智能推荐

6

user_id

int

10

0

N

N

0

用户ID

7

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表turnover (营业额)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

turnover_id

int

10

0

N

Y

营业额ID

2

date

date

10

0

Y

N

日期

3

turnover

int

10

0

Y

N

0

营业额

4

expenditure

int

10

0

Y

N

0

支出

5

profit

varchar

64

0

Y

N

利润

6

remarks

varchar

64

0

Y

N

备注

7

recommend

int

10

0

N

N

0

智能推荐

8

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

9

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表waiter (服务员)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

waiter_id

int

10

0

N

Y

服务员ID

2

service_employee_number

varchar

64

0

Y

N

服务员工号

3

waiters_name

varchar

64

0

Y

N

服务员姓名

4

examine_state

varchar

16

0

N

N

已通过

审核状态

5

recommend

int

10

0

N

N

0

智能推荐

6

user_id

int

10

0

N

N

0

用户ID

7

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

4 酒店点餐系统设计与实现

酒店点餐系统的详细设计与实现主要是根据前面的酒店点餐系统的需求分析和酒店点餐系统的总体设计来设计页面并实现业务逻辑。主要从酒店点餐系统 界面实现、业务逻辑实现这两部分进行介绍

4.1 系统首页页面

当进入酒店点餐系统的时候,首先映入眼帘的是系统的导航栏,下面是轮播图以及系统内容,其主界面展示如下图4.1所示。

图4.1 用户首页界面图

4.2 注册页面

不是酒店点餐系统中正式用户的是可以在线进行注册的,如果你没有本酒店点餐系统 的账号的话,添加“注册”,当填写上自己的账号+密码+确认密码+昵称+邮箱+手机号等后再点击“注册”按钮后将会先验证输入的有没有空数据,再次验证密码和确认密码是否是一样的,最后验证输入的账户名和数据库表中已经注册的账户名是否重复,只有都验证没问题后即可用户注册成功。注册界面实现了用户的注册,其注册界面展示如下图4。2所示。

图4.2 注册界面图

注册用户注册逻辑代码如下:

/**

     * 注册

     * @return

     */

    @PostMapping("register")

    public Map<String, Object> signUp(HttpServletRequest request) throws IOException {

        // 查询用户

        Map<String, String> query = new HashMap<>();

        Map<String,Object> map = service.readBody(request.getReader());

        query.put("username",String.valueOf(map.get("username")));

        List list = service.selectBaseList(service.select(query, new HashMap<>()));

        if (list.size()>0){

            return error(30000, "用户已存在");

        }

        map.put("password",service.encryption(String.valueOf(map.get("password"))));

        service.insert(map);

        return success(1);

}

    public Map<String,Object> readBody(BufferedReader reader){

        BufferedReader br = null;

        StringBuilder sb = new StringBuilder("");

        try{

            br = reader;

            String str;

            while ((str = br.readLine()) != null){

                sb.append(str);

            }

            br.close();

            String json = sb.toString();

            return JSONObject.parseObject(json, Map.class);

        }catch (IOException e){

            e.printStackTrace();

        }finally{

            if (null != br){

                try{

                    br.close();

                }catch (IOException e){

                    e.printStackTrace();

                }

            }

        }

        return null;

    }

    public void insert(Map<String,Object> body){

        E entity = JSON.parseObject(JSON.toJSONString(body),eClass);

        baseMapper.insert(entity);

        log.info("[{}] - 插入操作:{}",entity);

}

4.3 登录页面

酒店点餐系统中的前台上注册后的用户是可以通过自己的账户名和密码进行登录的,当用户输入完整的自己的账户名和密码信息并点击“登录”按钮后,将会首先验证输入的有没有空数据,再次验证输入的账户名+密码和数据库中当前保存的用户信息是否一致,只有在一致后将会登录成功并自动跳转到酒店点餐系统 的首页中;否则将会提示相应错误信息,用户登录界面如下图4.3所示。

图4.3 登录界面图

注册用户登录的逻辑代码如下所示。

/**

     * 登录

     * @param data

     * @param httpServletRequest

     * @return

     */

    @PostMapping("login")

    public Map<String, Object> login(@RequestBody Map<String, String> data, HttpServletRequest httpServletRequest) {

        log.info("[执行登录接口]");

        String username = data.get("username");

        String email = data.get("email");

        String phone = data.get("phone");

        String password = data.get("password");

        List resultList = null;

        QueryWrapper wrapper = new QueryWrapper<User>();

        Map<String, String> map = new HashMap<>();

        if(username != null && "".equals(username) == false){

            map.put("username", username);

            resultList = service.selectBaseList(service.select(map, new HashMap<>()));

        }

        else if(email != null && "".equals(email) == false){

            map.put("email", email);

            resultList = service.selectBaseList(service.select(map, new HashMap<>()));

        }

        else if(phone != null && "".equals(phone) == false){

            map.put("phone", phone);

            resultList = service.selectBaseList(service.select(map, new HashMap<>()));

        }else{

            return error(30000, "账号或密码不能为空");

        }

        if (resultList == null || password == null) {

            return error(30000, "账号或密码不能为空");

        }

        //判断是否有这个用户

        if (resultList.size()<=0){

            return error(30000,"用户不存在");

        }

        User byUsername = (User) resultList.get(0);

        Map<String, String> groupMap = new HashMap<>();

        groupMap.put("name",byUsername.getUserGroup());

        List groupList = userGroupService.selectBaseList(userGroupService.select(groupMap, new HashMap<>()));

        if (groupList.size()<1){

            return error(30000,"用户组不存在");

        }

        UserGroup userGroup = (UserGroup) groupList.get(0);

        //查询用户审核状态

        if (!StringUtils.isEmpty(userGroup.getSourceTable())){

            String res = service.selectExamineState(userGroup.getSourceTable(),byUsername.getUserId());

            if (res==null){

                return error(30000,"用户不存在");

            }

            if (!res.equals("已通过")){

                return error(30000,"该用户审核未通过");

            }

        }

        //查询用户状态

        if (byUsername.getState()!=1){

            return error(30000,"用户非可用状态,不能登录");

        }

        String md5password = service.encryption(password);

        if (byUsername.getPassword().equals(md5password)) {

            // 存储Token到数据库

            AccessToken accessToken = new AccessToken();

            accessToken.setToken(UUID.randomUUID().toString().replaceAll("-", ""));

            accessToken.setUser_id(byUsername.getUserId());

            tokenService.save(accessToken);

            // 返回用户信息

            JSONObject user = JSONObject.parseObject(JSONObject.toJSONString(byUsername));

            user.put("token", accessToken.getToken());

            JSONObject ret = new JSONObject();

            ret.put("obj",user);

            return success(ret);

        } else {

            return error(30000, "账号或密码不正确");

        }

}

    public String select(Map<String,String> query,Map<String,String> config){

        StringBuffer sql = new StringBuffer("select ");

        sql.append(config.get(FindConfig.FIELD) == null || "".equals(config.get(FindConfig.FIELD)) ? "*" : config.get(FindConfig.FIELD)).append(" ");

        sql.append("from ").append("`").append(table).append("`").append(toWhereSql(query, "0".equals(config.get(FindConfig.LIKE))));

        if (config.get(FindConfig.GROUP_BY) != null && !"".equals(config.get(FindConfig.GROUP_BY))){

            sql.append("group by ").append(config.get(FindConfig.GROUP_BY)).append(" ");

        }

        if (config.get(FindConfig.ORDER_BY) != null && !"".equals(config.get(FindConfig.ORDER_BY))){

            sql.append("order by ").append(config.get(FindConfig.ORDER_BY)).append(" ");

        }

        if (config.get(FindConfig.PAGE) != null && !"".equals(config.get(FindConfig.PAGE))){

            int page = config.get(FindConfig.PAGE) != null && !"".equals(config.get(FindConfig.PAGE)) ? Integer.parseInt(config.get(FindConfig.PAGE)) : 1;

            int limit = config.get(FindConfig.SIZE) != null && !"".equals(config.get(FindConfig.SIZE)) ? Integer.parseInt(config.get(FindConfig.SIZE)) : 10;

            sql.append(" limit ").append( (page-1)*limit ).append(" , ").append(limit);

        }

        log.info("[{}] - 查询操作,sql: {}",table,sql);

        return sql.toString();

}

    public List selectBaseList(String select) {

        List<Map<String,Object>> mapList = baseMapper.selectBaseList(select);

        List<E> list = new ArrayList<>();

        for (Map<String,Object> map:mapList) {

            list.add(JSON.parseObject(JSON.toJSONString(map),eClass));

        }

        return list;

}

4.4 酒店资讯页面

当用户点击酒店资讯以后就会进入到以下界面,用户可以输入关键词搜索资讯内容,查看点赞数以及点击数,然后点击到资讯的详细的界面,在这个详细界面可以点赞+评论。其出界面展示如下图4.4所示。

图4.4 酒店资讯界面图

4.5点餐菜谱页面

当用户点击“点餐菜谱”以后就会给我们展示点餐菜谱的列表,选择一个点餐菜谱进入到图4.5界面中,用户可以对点餐菜谱进行下单,点击下单按钮,进入到4.6界面中,输入订单号、菜品名称、价格、总金额、联系电话、订单备注、菜品编号、菜品类别、数量、用户、餐桌号等,点击“提交”按钮,就会显示下成功。

图4.5 点餐菜谱界面图

图4.6 下单界面图

点餐菜谱的逻辑代码如下:

@RequestMapping(value = "/del")

    @Transactional

    public Map<String, Object> del(HttpServletRequest request) {

        service.delete(service.readQuery(request), service.readConfig(request));

        return success(1);

}

4.6 修改密码页面

用户使用该酒店点餐系统注册完成后,用户对登录密码有修改需求时,系统也可以提供用户修改密码权限。系统中所有的操作者能够变更自己的密码信息,执行该功能首先必须要登入系统,然后选择密码变更选项以后在给定的文本框中填写初始密码和新密码来完成修改密码的操作。在填写的时候,假如两次密码填写存在差异,那么此次密码变更操作失败,下面的图片展示的就是该板块对应的工作面。其界面展示如下图4.7所示。

图4.7 密码修改界面图

4.7公共管理页面

管理员点击“公共管理”这一菜单会显示轮播图、酒店公告这两个子菜单,管理员可以对前台展示的酒店公告和轮播图进行设置,界面如下图4.8所示。

图4.8 公共管理界面图

公共管理关键代码如下所示。

public List selectBaseList(String select) {

        List<Map<String,Object>> mapList = baseMapper.selectBaseList(select);

        List<E> list = new ArrayList<>();

        for (Map<String,Object> map:mapList) {

            list.add(JSON.parseObject(JSON.toJSONString(map),eClass));

        }

        return list;

}

4.8 用户管理页面

管理员点击“用户管理”这一菜单会显示管理员、注册用户以及服务员这三个子菜单,管理员可以对这三个角色的信息进行增删改查操作。界面如下图4.9所示。

图4.9 用户管理界面图

4.9 酒店资讯管理页面

点击“酒店资讯”按钮会显示自己添加的酒店资讯信息,如果想要添加新的酒店资讯信息,点击“添加”按钮根据提示输入酒店资讯信息,点击“提交”后在酒店资讯界面就可以显示了,如果信息有错可以对酒店资讯信息进行更新维护,也可以直接删除某一酒店资讯,还可以管理评论信息,界面如下图4.10所示。

图4.10酒店资讯管理界面图

4.10 订单中心管理页面

管理员点击“订单中心”会显示出所有的订单中心信息,支持输入订单号或者菜品编号或者菜品名称对订单中心信息进行查询,如果想要添加新的订单中心信息,点击“添加”按钮,输入相关信息,点击“提交”按钮就可以添加了,同时可以选择某一条订单中心信息,点击“删除”进行删除,也可以点击后面的“支付”按钮对订单中心的订单进行更新维护、对订单中心的支付信息进行设置。界面如下图4.11所示。

图4.11 订单中心管理界面图

4.11预定餐桌管理页面

管理员点击“预定餐桌”会显示出所有的预定餐桌信息,支持通过预定餐桌状态或者输入餐桌类型或者可座人数或者用户对预定餐桌信息进行查询,如果想要添加新的预定餐桌信息,点击“添加”按钮,输入相关信息,点击“提交”按钮就可以添加了,同时可以选择某一条预定餐桌信息,点击“删除”进行删除。界面如下图4.12所示。

图4.12 预定餐桌管理界面图

5酒店点餐系统测试

酒店点餐系统测试是为了检验软件是否达到设计要求,是否存在错误,通过测试的方法来检查酒店点餐系统,以便发现酒店点餐系统中的错误。测试工作是保证酒店点餐系统质量的关键。

5.1 调试部分问题

问题1:数据库无法添加中文。

解决过程:重新创建数据库,将库的编码格式改为utf8。

效果:能在新库的表中添加中文。

问题2:控制台报错前台与后台参数不一致

解决过程:检查代码,找到报错参数完成修改,继续报错,服务器移除项目重新运行。

效果:重启项目不再报错。

问题3:报错No bean named 'sysLogServiceImpl' available找不到名为sysLogServiceImpl的bean的对象。

解决过程:询问导师报错原因,发现错误原因是未添加注解@Service,需要在在impl实现类的外面添加@Service注解。

效果:重新debug项目无报错。

问题4:启动项目时报错:Mapped Statements collection does not contain value for

解决过程:网上搜索解决办法,出错可能的原因有多个,经过努力排查,错误原因是mapper映射地址有误。在mybatis-config里重新配置地址。

效果:项目启动正常

5.2 系统测试用例

系统测试包括:点餐菜谱添加功能测试、餐厅餐桌功能测试、预定餐桌添加功能测试、订单中心功能测试这四大功能测试,如表5.1到5.4所示:

表5.1点餐菜谱添加功能测试表

测试名称

测试功能

操作过程

预期结果

测试结果

点餐菜谱添加功能模块测试

管理员添加点餐菜谱功能是否正常

管理员登录成功后点击“添加点餐菜谱”菜单

管理员根据提示并依次输入点菜品编号+菜品名称+图片+菜品类别等,后点击“提交”按钮

点餐菜谱添加信息功能正常

表5.2 餐厅餐桌功能测试表

测试名称

测试功能

操作过程

预期结果

测试结果

餐厅餐桌添加功能模块测试

注册用户添加餐厅餐桌功能是否正常

注册用户登录成功后点击“添加餐厅餐桌”菜单

注册用户根据提示并依次输入餐桌类型+图片+可座人数+不足等,后点击“提交”按钮

餐厅餐桌添加信息功能正常

表5.3 预定餐桌添加功能测试表

测试名称

测试功能

操作过程

预期结果

测试结果

预定餐桌添加功能模块测试

预定餐桌添加预定餐桌功能是否正常

管理员登录成功后点击“添加预定餐桌”菜单

管理员根据提示并依次输入餐桌类型+用户+就餐人数+姓名+联系电话点击“提交”按钮

预定餐桌添加信息功能正常

表5.4订单中心功能测试表

测试名称

测试功能

操作过程

预期结果

测试结果

订单中心功能模块测试

订单中心功能是否正常

注册用户登录成功后点击订单中心中的“开取”按钮

注册用户根据提示填写充值信息点击“提交”按钮

订单中心信息功能正常

5.3 系统测试结果

通过上面章节编写酒店点餐系统的测试用例,已经测试完毕了点餐菜谱添加功能测试、餐厅餐桌测试、预定餐桌添加功能测试、订单中心功能测试,通过这4大模块为酒店点餐系统的后期推广运营提供了强力的技术支撑。

                                                    结论

至此,酒店点餐系统已经结束,在开发前做了许多的准备,在本系统的设计和开发过程中阅览和学习了许多文献资料,从中我也收获了很多宝贵的方法和设计思路,对系统的开发也起到了很重要的作用,系统的开发技术选用的都是自己比较熟悉的,比如SSM、JAVA技术、MYSQL,这些技术都是在以前的学习中学到了,其中许多的设计思路和方法都是在以前不断地学习中摸索出来的经验,其实对于我们来说工作量还是比较大的,但是正是由于之前的积累与准备,才能顺利的完成这个项目,由此看来,积累经验跟做好准备是十分重要的事情。

当然在该系统的设计与实现的过程中也离不开老师以及同学们的帮助,正是因为他们的指导与帮助,我才能够成功的在预期内完成了这个系统。同时在这个过程当中我也收获了很多东西,此系统也有需要改进的地方,但是由于专业知识的浅薄,并不能做到十分完美,希望以后有机会可以让其真正的投入到使用之中。

                                                      参考文献

[1]申志强,田玉兵. 一种JAVA类实例和目标格式数据的转换方法和装置[P]. 北京市:CN115455239B,2023-01-06.

[2]常婉纶,谈姝辰,屈小娥,田召.基于SSM框架的二级学院教科研信息共享系统的设计与实现[J].电脑知识与技术,2022,18(34):39-41.DOI:10.14004/j.cnki.ckt.2022.2208.

[3]刘德凤.酒店点餐系统的设计与实现[J].电子技术与软件工程,2022(22):173-176.

[4]沈志元,张文健.基于Java技术的医院管理系统的设计与实现[J].电脑知识与技术,2022,18(32):38-40+54.DOI:10.14004/j.cnki.ckt.2022.1994.

[5]梁倩,文建平. 一种基于SSM框架的云笔记系统[P]. 天津市:CN115248676A,2022-10-28.

[6]王棋.基于SSM框架的网上摄影系统设计与实现[J].电子质量,2022(10):89-93.

[7]杨玉莲.基于SSM框架的智能煤质化验室综合管理系统[J].煤矿现代化,2022,31(05):100-104+109.DOI:10.13606/j.cnki.37-1205/td.2022.05.005.

[8]唐小玲.基于SSM框架的资质管理系统开发解析[J].科学技术创新,2022(26):80-83.

[9]. OpenSolar and Segen Highlight Intelligent Solar Design, Proposal and Equipment Ordering System[J]. Wireless News,2022.

[10]张浩博, 基于Java的计算机技术开发研究管理系统V1.0. 湖北省,武汉东湖学院,2021-07-01.

[11]. Contactless Menu/Food Ordering System For Small Restaurant, Cafe, and Food Truck Owners[J]. M2 Presswire,2021.

[12]时庭庭. 酒店会员点餐系统的设计与实现[D].东华大学,2021.DOI:10.27012/d.cnki.gdhuu.2021.000018.

[13]张梦琳, 基于Java的编程语言工具应用软件V1.0. 湖北省,武汉东湖学院,2021-04-01.

[14], 专科(678人) 软件技术(Java方向)(225人). 朱金瑞 主编,河南财经政法大学年鉴,中州古籍出版社,2018,525-526,年鉴.DOI:10.38722/y.cnki.ycjzf.2020.001067.

[15]肖睿,崔雪炜,艾华,潘亚,张娟. Java面向对象程序开发及实战[M].人民邮电出版社:大数据开发实战系列, 201801.209.

[16]蒙灏,何灵敏.基于微信的无线点餐系统设计[J].福建电脑,2016,32(12):28-29.DOI:10.16707/j.cnki.fjpc.2016.12.016.

[17]尹玉麒,章晓敏,金凯伟.酒店点餐系统系统架构分析与实现[J].科技展望,2016,26(33):89+162.

[18]李一凡,余杰,沈洁.“云媒体电视”美食点餐系统建设[J].中国有线电视,2016(08):926-929.

[19]YONGGANG ZUO,WEIPING ZHU. Aviation Logistics Information System Based on SSM Framework[P]. 2nd International Conference on Computer Engineering, Information Science and Internet Technology (CII 2017),2017.

                                               致  谢

时间过的很快,不知不觉,在中北大学的学习生活即将结束。毕业之际,我真诚地向帮助过我的老师、家人、同学、朋友们表达感谢。首先要感谢的是我的母校。感谢母校给了我美好的生活和优越的学习环境,使我能学到了很多知识,也不断的变得优秀;感谢家人在这四年期间一直给与我的爱和无条件的支持,让我没有后顾之忧地完成学业;感谢软件学院的任课老师们给我鼓励和认可,让我有信心去做好每一件事情;感谢同学们的帮助,让我的大用户活更有意义。在此次毕业设计的实现过程中, 我得到了老师们的耐心指导让我顺利完成了该设计。从最初的选题和开题开始,老师就给予我很多帮助,他们认真负责的态度、丰富的教学经验让我学到了很多。

同时也要感谢我敬爱的班主任和实训课程的老师,他们在各个方面都教给了我丰富的经验,在面对各种困难时如何处理。因为今年的特殊性,老师们不仅在学习中给我以精心的指导,同时还在其它方面给予我观关怀,指导老师不辞辛苦的为大家录制视频和一遍遍讲解让我心怀感激之情。在此,我真诚的感恩、感谢我的指导教师们。

还要感谢实习期间不厌其烦教导我鼓励我的技术师傅,他指导了我各个方面的技巧,尤其是编程方面,迄今我的很多技巧和编写规范都有赖于他的指导、纠正。

最后还要特别感谢身边的各位同学们,一直支持鼓励我,无论何时何种境况。我很荣幸获得同学们的帮助,也很开心能够和大家共度大学四年的时光。

最后的最后,再次发自肺腑的感谢所有帮助过我的人。

           免费领取源码,请点赞关注私信博主                         

;