node.js装修接单小程序-计算机毕业设计源码03024

目  录

摘要

1 绪论

1.1 研究背景

1.2 研究意义

1.3微信开发者工具介绍

2 系统分析

2.1 可行性分析

2.2 系统流程分析

2.2.1 数据新增流程

2.2.2 数据删除流程

2.3 系统功能分析

2.4 系统用例分析

3 系统总体设计

3.1 系统功能模块设计

3.2 数据库设计

3.2.1 数据库概念结构设计

3.2.2 数据库逻辑结构设计

表access_token (登陆访问时长)

表article (文章:用于内容管理系统的文章)

表article_type (文章分类)

表auth (用户权限管理)

表collect (收藏)

表comment (评论)

表customer_users (客户用户)

表decoration_cases (装修案例)

表decoration_type (装修类型)

表forum (论坛)

表forum_type (论坛分类)

表hits (用户点击)

表notice (公告)

表order_information (接单信息)

表praise (点赞)

表requirement_information (需求信息)

表sensitive_vocabulary (敏感词汇)

表slides (轮播图)

表upload (文件上传)

表user (用户账户:用于保存用户登录信息)

表user_group (用户组:用于用户前端身份和鉴权)

表worker_users (工人用户)

4 系统详细设计与实现

4.1用户端

4.1.1 注册登录模块

(1)用户注册界面

(2)用户登录界面

4.1.2 客户用户功能模块

(1)首页界面

(2)在线互动界面

(3)装修资讯界面

(4)我的界面

(5)在线客服界面

4.1.3 工人用户功能模块

(1)在线互动界面

(2)我的界面

4.2 Web管理端

4.2.1 系统用户界面

4.2.2装修类型管理界面

4.2.3装修案例管理界面

4.2.4接单信息管理界面

4.2.5系统管理界面

4.2.6系统公告管理界面

4.2.7资源管理界面

4.2.8交流管理界面

5系统测试

5.1 系统测试目的

5.2系统测试用例

5.3 系统测试结果

6 结论

参考文献

致  谢

摘要

随着移动互联网的快速发展,传统装修行业正面临转型升级的压力。为了满足消费者日益增长的个性化需求,装修行业亟需借助数字化手段提升服务效率和用户体验。装修接单小程序作为一种新型业务模式,具有便捷性、高效性和低成本等优势,逐渐成为装修企业的新宠。Node.js作为一种强大的后端技术平台,具有非阻塞I/O模型和单线程事件循环机制等特点,能有效应对高并发和实时响应场景。因此,将Node.js应用于装修接单小程序的开发具有重要意义。

本文首先阐述了装修接单小程序的研究背景和意义;然后对小程序的设计进行了可行性、功能性等分析;接着详细介绍了装修接单小程序的设计原理和实现细节,包括主要功能模块设计、数据库设计等;最后对装修接单小程序进行了部署和测试。通过本小程序的成功开发,不仅为我国的装修行业提供了有力支持,也为其他类似系统的设计和实现提供了有益的参考。

关键词:装修行业;接单小程序;Node.js

Abstract

With the rapid development of mobile Internet, the traditional decoration industry is facing the pressure of transformation and upgrading. In order to meet the growing personalized needs of consumers, the decoration industry urgently needs to use digital means to improve service efficiency and user experience. As a new business model, the decoration order receiving mini program has advantages such as convenience, efficiency, and low cost, and has gradually become a new favorite of decoration enterprises. Node.js, as a powerful backend technology platform, has the characteristics of a non blocking I/O model and a single threaded event loop mechanism, which can effectively respond to high concurrency and real-time response scenarios. Therefore, applying Node.js to the development of decoration order receiving mini programs is of great significance.

This article first elaborates on the research background and significance of the decoration order receiving mini program; Then feasibility and functionality analysis were conducted on the design of the mini program; Then, the design principle and implementation details of the decoration order receiving mini program were introduced in detail, including the main functional module design, database design, etc; Finally, the decoration order receiving mini program was deployed and tested. The successful development of this mini program not only provides strong support for China's decoration industry, but also provides useful references for the design and implementation of other similar systems.

Keywords: Decoration industry; Order receiving mini program; Node.js

1 绪论

1.1 研究背景

装修行业市场需求大,但痛点也不少。传统的装修市场存在着信息不对称、服务不透明等问题,导致许多消费者在选择装修公司时无从下手,也难以保证装修质量和进度。随着移动互联网的普及和技术的不断发展,小程序作为一种轻量级的应用程序形式,越来越受到开发者和用户的青睐。由于其具有跨平台、易于开发、便于分享等特点,小程序在装修行业也有着广泛的应用前景。通过 Node.js 开发的装修接单小程序,可以提供一个线上平台,整合装修资源,实现信息的透明化和服务的标准化。满足装修行业的需求。

1.2 研究意义

随着科技的飞速发展,互联网已经深入到我们生活的方方面面,开发设计一个装修接单小程序具有重要的意义。

首先,可以提高装修行业效率:传统的装修行业,从业主需求发布、装修公司报价、签订合同施工,整个流程繁琐且耗时较长。而装修接单小程序将这一流程简化,业主可以通过小程序快速发布装修需求,装修公司可以在第一时间信息,并进行报价、抢单。这样,双方可以迅速达成合作,提高了装修行业的整体效率。

其次,可以降低装修成本:装修接单小程序的出现,使得装修公司无需再花费大量资金进行线下推广,即可获得充足的业务来源。同时,小程序的运营成本较低,装修公司可以节省大量成本,将这些资金用于提高装修质量和售后服务。

再次,有助于促进装修行业的数字化转型:随着互联网的普及,装修行业也逐渐向数字化转型。装修接单小程序作为一种商业模式,将客户、工人等多方纳入到一个生态圈中,实现了信息的快速流通和共享。这种数字化转型有助于推动装修行业的健康发展,提高行业整体竞争力。

最后,可以提升业主装修体验:装修接单小程序为业主提供了便捷、高效的装修服务,业主可以随时随地查看装修案例、在线提交装修需求和查看接单信息,有助于提升业主的装修体验。

1.3微信开发者工具介绍

微信开发者工具是一款专为小程序开发而设计的应用,它不断改进,提供了便捷的操作方式,并且在开发过程中可以通过微信扫描二维码来访问,从而实现快速、准确的小程序开发和调试。

根据用户的需求,我们将采用不同的屏幕大小来制作小程序,并对其进行精确的切割。

在完成了视图布置之后,可以通过执行编辑功能,快速更改视图界面。

控制台:方便调试打印输出信息。

将代码上传至腾讯服务器,并在审核过程中填写版本号和备注信息,以确保代码的安全性和准确性。

通过查看资源文件,我们可以快速地调整相关项目的文件目录,从而实现断点调试。

使用远程调试技术,无论是在手机端还是PC端,都能够轻松地进行开发工作。

本地数据存储:显示的是本地存储的数据。

通过使用子父层级结构,我们可以更容易地进行视图调试。

微信的代码体积应该保持在2M 以内,而且在开发过程中,应该严格检查合法域名信息,并且为小程序的后台配置服务器域名。

微信开发者工具已经成为了开发过程中不可或缺的一部分,并且正在不断地改进和完善。

2 系统分析

2.1 可行性分析

(1)技术可行性:

Node.js是一个基于Chrome V8 引擎的 JavaScript 运行环境,它可以让 JavaScript 脱离浏览器运行,从而在服务器端执行。因此,使用 Node.js 可以轻松地构建出一个小程序的后端服务,同时也可以通过小程序的开发工具和 API来实现前端页面的交互效果。因此,从技术角度分析是可行的。

(2)经济可行性:

Node.js 拥有丰富的库和模块,如 Express、MongoDB、Redis 等,可以帮助开发者快速搭建应用程序。在装修接单小程序的开发过程中,开发者可以方便地使用这些开源组件,提高开发效率。此外,Node.js 基于 Chrome V8 引擎,实现了跨平台运行。这意味着开发者可以使用同一套代码同时在 Windows、Mac、Linux 等操作系统上部署应用程序,大大降低了开发和维护成本。因此,从经济角度分析是可行的。

  1. 市场可行性:

在我国,房地产市场和装修市场一直保持着热度。与此同时,越来越多的年轻人倾向于通过互联网解决装修问题,他们希望能够找到一家靠谱的装修公司或设计师,为自己提供专业、贴心的服务。随着移动互联网的普及,装修接单小程序有着广阔的市场需求。因此,从市场角度分析是可行的。

2.2 系统流程分析

系统流程是用一些特定的符合和线条来进行演示用户在使用系统时的过程,在进行系统分析的时候,业务流程可以帮助开发人员更好的理解业务,发现错误,完善系统。

2.2.1 数据新增流程

用户成功登入系统后能够实现增加数据的操作,增加数据的编号系统生成,用户不能随意填写,除了编号以外,其他增加信息用户自己填写,填写后的信息经过系统验证,验证通过后即可完成数据新增数据新增的流程图如下图2-1所示

图2-1  数据新增流程图

2.2.2 数据删除流程

如果系统里面存在一些没有用的数据,相关的管理人员还可以对这些数据进行删除,数据删除时流程图如下图2-2所示

图2-2  数据删除流程图

2.3 系统功能分析

按照装修接单小程序序的角色,主要包括微信端和管理端两大功能模块,各模块功能内容如下:

  1. 用户端:
  1. 客户用户功能
  • 首页:用户可以查看首页展示的轮播图、装修案例、装修资讯、需求信息等内容。
  • 注册登录:游客可以通过注册成为系统用户,注册后可以通过账号密码登录。
  • 在线互动:用户可以查看在线互动列表中某个帖子的详情信息并可以进行点赞、收藏和发表评论操作。
  • 装修资讯:用户可以查看装修资讯列表中某一资讯详情并进行点赞、收藏和发表评论操作。
  • 我的:用户可以查看和管理我的页面中的基本信息、收藏、需求信息、接单信息和论坛管理信息。
  • 在线客服:用户点击首页右下方的女生头像可以进入在线客服聊天界面与客服进行沟通。
  1. 工人用户功能
  • 首页:用户可以查看首页展示的轮播图、装修案例、装修资讯、需求信息等内容。
  • 注册登录:游客可以通过注册成为系统用户,注册提交后需由管理员在后台管理端审核通过才能登录。
  • 在线互动:用户可以查看在线互动列表中某个帖子的详情信息并可以进行点赞、收藏和发表评论操作。
  • 装修资讯:用户可以查看装修资讯列表中某一资讯详情并进行点赞、收藏和发表评论操作。
  • 我的:用户可以查看和管理我的界面中的基本信息、收藏、装修案例、接单信息和论坛管理信息。
  • 在线客服:用户点击首页右下方的女生头像可以进入在线客服聊天界面与客服进行沟通。
  1. 管理端:
  • 后台首页:管理员可以查看后台首页展示的相关信息。
  • 系统用户:管理员可以对系统用户信息进行查询、重置、添加和删除操作。
  • 装修类型管理:管理员可以对装修类型信息进行查询、重置、添加和删除操作。
  • 装修案例管理:管理员可以对装修案例信息进行查询、重置、添加和删除操作。
  • 需求信息管理:管理员可以对需求信息进行查询、重置、添加和删除操作。
  • 接单信息管理:管理员可以对接单信息进行查询、重置和删除操作。
  • 系统管理:管理员可以对系统轮播图信息进行查询、添加、重置和删除操作。
  • 系统公告管理:管理员可以系统公告信息进行查询、添加、重置和删除操作。
  • 资源管理:管理员可以对装修资讯、分类列表信息进行查询、添加、重置和删除操作。
  • 交流管理:管理员可以对在线互动、分类列表信息进行查询、重置、添加和删除操作。
  • 我的:管理员可以修改个人信息和登录密码。

2.4 系统用例分析

通过2.3功能的分析,得出了本装修接单小程序的用例图:

客户用户角色用例图如下图2-3所示。

图2-3客户用户角色用例图

工人用户角色用例图如下图2-4所示。

图2-5工人用户角色用例图

管理员角色用例图如下图2-6所示。

图2-6管理员角色用例图

3 系统总体设计

3.1 系统功能模块设计

通过对装修接单小程序的功能分析以及用例分析,得出了装修接单小程序的整体功能模块图,如下图3-1所示。

图3-1装修接单小程序整体功能模块图

3.2 数据库设计

数据库设计一般包括需求分析、概念模型设计、数据库表建立三大过程,其中需求分析前面章节已经阐述,概念模型设计有概念模型和逻辑结构设计两部分。

3.2.1 数据库概念结构设计

下面是整个装修接单小程序序中主要的数据库表总E-R实体关系图。

图3-2 系统总E-R关系图

3.2.2 数据库逻辑结构设计

通过上一小节中装修接单小程序序中总E-R关系图上得出一共需要创建很多个数据表。在此主要罗列几个主要的数据库表结构设计。

表access_token (登陆访问时长)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

token_id

int

10

0

N

Y

临时访问牌ID

2

token

varchar

64

0

Y

N

临时访问牌

3

info

text

65535

0

Y

N

4

maxage

int

10

0

N

N

2

最大寿命:默认2小时

5

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

6

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

7

user_id

int

10

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

分类名称:[2,16]

4

father_id

smallint

5

0

N

N

0

上级分类ID:[0,32767]

5

description

varchar

255

0

Y

N

描述:[0,255]描述该分类的作用

6

icon

text

65535

0

Y

N

分类图标:

7

url

varchar

255

0

Y

N

外链地址:[0,255]如果该分类是跳转到其他网站的情况下,就在该URL上设置

8

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

9

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表auth (用户权限管理)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

auth_id

int

10

0

N

Y

授权ID:

2

user_group

varchar

64

0

Y

N

用户组:

3

mod_name

varchar

64

0

Y

N

模块名:

4

table_name

varchar

64

0

Y

N

表名:

5

page_title

varchar

255

0

Y

N

页面标题:

6

path

varchar

255

0

Y

N

路由路径:

7

position

varchar

32

0

Y

N

位置:

8

mode

varchar

32

0

N

N

_blank

跳转方式:

9

add

tinyint

3

0

N

N

1

是否可增加:

10

del

tinyint

3

0

N

N

1

是否可删除:

11

set

tinyint

3

0

N

N

1

是否可修改:

12

get

tinyint

3

0

N

N

1

是否可查看:

13

field_add

text

65535

0

Y

N

添加字段:

14

field_set

text

65535

0

Y

N

修改字段:

15

field_get

text

65535

0

Y

N

查询字段:

16

table_nav_name

varchar

500

0

Y

N

跨表导航名称:

17

table_nav

varchar

500

0

Y

N

跨表导航:

18

option

text

65535

0

Y

N

配置:

19

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

20

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:空为0

4

content

longtext

2147483647

0

Y

N

内容:

5

nickname

varchar

255

0

Y

N

昵称:

6

avatar

varchar

255

0

Y

N

头像地址:[0,255]

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:

表customer_users (客户用户)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

customer_users_id

int

10

0

N

Y

客户用户ID

2

user_name

varchar

64

0

Y

N

用户姓名

3

user_gender

varchar

64

0

Y

N

用户性别

4

interest_style

varchar

64

0

Y

N

兴趣风格

5

examine_state

varchar

16

0

N

N

已通过

审核状态

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

更新时间

表decoration_cases (装修案例)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

decoration_cases_id

int

10

0

N

Y

装修案例ID

2

worker_users

int

10

0

Y

N

0

工人用户

3

worker_name

varchar

64

0

Y

N

工人姓名

4

decoration_theme

varchar

64

0

Y

N

装修主题

5

decoration_style

varchar

64

0

Y

N

装修风格

6

style_display

varchar

255

0

Y

N

风格展示

7

start_time

date

10

0

Y

N

开始时间

8

completion_time

date

10

0

Y

N

完工时间

9

decoration_details

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

更新时间

表decoration_type (装修类型)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

decoration_type_id

int

10

0

N

Y

装修类型ID

2

type_name

varchar

64

0

Y

N

类型名称

3

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

4

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表forum (论坛)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

forum_id

mediumint

8

0

N

Y

论坛id

2

display

smallint

5

0

N

N

100

排序

3

user_id

mediumint

8

0

N

N

0

用户ID

4

nickname

varchar

16

0

Y

N

昵称:[0,16]

5

praise_len

int

10

0

Y

N

0

点赞数

6

hits

int

10

0

N

N

0

访问数

7

title

varchar

125

0

N

N

标题

8

keywords

varchar

125

0

Y

N

关键词

9

description

varchar

255

0

Y

N

描述

10

url

varchar

255

0

Y

N

来源地址

11

tag

varchar

255

0

Y

N

标签

12

img

text

65535

0

Y

N

封面图

13

content

longtext

2147483647

0

Y

N

正文

14

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

15

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

16

avatar

varchar

255

0

Y

N

发帖人头像:

17

type

varchar

64

0

N

N

0

论坛分类:[0,1000]用来搜索指定类型的论坛帖

表forum_type (论坛分类)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

type_id

smallint

5

0

N

Y

分类ID:[0,10000]

2

name

varchar

16

0

N

N

分类名称:[2,16]

3

description

varchar

255

0

Y

N

描述:[0,255]描述该分类的作用

4

url

varchar

255

0

Y

N

外链地址:[0,255]如果该分类是跳转到其他网站的情况下,就在该URL上设置

5

father_id

smallint

5

0

N

N

0

上级分类ID:[0,32767]

6

icon

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

更新时间:

表hits (用户点击)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

hits_id

int

10

0

N

Y

点赞ID:

2

user_id

int

10

0

N

N

0

点赞人:

3

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

4

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

5

source_table

varchar

255

0

Y

N

来源表:

6

source_field

varchar

255

0

Y

N

来源字段:

7

source_id

int

10

0

N

N

0

来源ID:

表notice (公告)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

notice_id

mediumint

8

0

N

Y

公告id:

2

title

varchar

125

0

N

N

标题:

3

content

longtext

2147483647

0

Y

N

正文:

4

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

5

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表order_information (接单信息)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

order_information_id

int

10

0

N

Y

接单信息ID

2

worker_users

int

10

0

Y

N

0

工人用户

3

worker_name

varchar

64

0

Y

N

工人姓名

4

work_id

varchar

64

0

Y

N

工作证件

5

customer_users

int

10

0

Y

N

0

客户用户

6

user_name

varchar

64

0

Y

N

用户姓名

7

requirement_number

varchar

64

0

N

N

需求编号

8

decoration_theme

varchar

64

0

Y

N

装修主题

9

expected_style

varchar

64

0

Y

N

期望风格

10

decoration_deposit

int

10

0

Y

N

0

装修定金

11

decoration_commission

int

10

0

Y

N

0

装修佣金

12

order_acceptance_time

datetime

19

0

Y

N

接单时间

13

order_acceptance_instructions

text

65535

0

Y

N

接单说明

14

examine_state

varchar

16

0

N

N

未审核

审核状态

15

examine_reply

varchar

16

0

Y

N

审核回复

16

pay_state

varchar

16

0

N

N

未支付

支付状态

17

pay_type

varchar

16

0

Y

N

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

18

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

19

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表praise (点赞)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

praise_id

int

10

0

N

Y

点赞ID:

2

user_id

int

10

0

N

N

0

点赞人:

3

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

4

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

5

source_table

varchar

255

0

Y

N

来源表:

6

source_field

varchar

255

0

Y

N

来源字段:

7

source_id

int

10

0

N

N

0

来源ID:

8

status

bit

1

0

N

N

1

点赞状态:1为点赞,0已取消

表requirement_information (需求信息)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

requirement_information_id

int

10

0

N

Y

需求信息ID

2

customer_users

int

10

0

Y

N

0

客户用户

3

user_name

varchar

64

0

Y

N

用户姓名

4

requirement_number

varchar

64

0

Y

N

需求编号

5

decoration_theme

varchar

64

0

Y

N

装修主题

6

expected_style

varchar

64

0

Y

N

期望风格

7

decoration_deposit

int

10

0

Y

N

0

装修定金

8

decoration_commission

int

10

0

Y

N

0

装修佣金

9

style_display

varchar

255

0

Y

N

风格展示

10

release_time

datetime

19

0

Y

N

发布时间

11

requirement_content

longtext

2147483647

0

Y

N

需求内容

12

hits

int

10

0

N

N

0

点击数

13

praise_len

int

10

0

N

N

0

点赞数

14

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

15

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表sensitive_vocabulary (敏感词汇)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

sensitive_vocabulary_id

int

10

0

N

Y

敏感词汇ID

2

sensitive_vocabulary

varchar

64

0

Y

N

敏感词汇

3

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

4

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表slides (轮播图)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

slides_id

int

10

0

N

Y

轮播图ID:

2

title

varchar

64

0

Y

N

标题:

3

content

varchar

255

0

Y

N

内容:

4

url

varchar

255

0

Y

N

链接:

5

img

varchar

255

0

Y

N

轮播图:

6

hits

int

10

0

N

N

0

点击量:

7

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表upload (文件上传)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

upload_id

int

10

0

N

Y

上传ID

2

name

varchar

64

0

Y

N

文件名

3

path

varchar

255

0

Y

N

访问路径

4

file

varchar

255

0

Y

N

文件路径

5

display

varchar

255

0

Y

N

显示顺序

6

father_id

int

10

0

Y

N

0

父级ID

7

dir

varchar

255

0

Y

N

文件夹

8

type

varchar

32

0

Y

N

文件类型

表user (用户账户:用于保存用户登录信息)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

user_id

mediumint

8

0

N

Y

用户ID:[0,8388607]用户获取其他与用户相关的数据

2

state

smallint

5

0

N

N

1

账户状态:[0,10](1可用|2异常|3已冻结|4已注销)

3

user_group

varchar

32

0

Y

N

所在用户组:[0,32767]决定用户身份和权限

4

login_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

上次登录时间:

5

phone

varchar

11

0

Y

N

手机号码:[0,11]用户的手机号码,用于找回密码时或登录时

6

phone_state

smallint

5

0

N

N

0

手机认证:[0,1](0未认证|1审核中|2已认证)

7

username

varchar

16

0

N

N

用户名:[0,16]用户登录时所用的账户名称

8

nickname

varchar

16

0

Y

N

昵称:[0,16]

9

password

varchar

64

0

N

N

密码:[0,32]用户登录所需的密码,由6-16位数字或英文组成

10

email

varchar

64

0

Y

N

邮箱:[0,64]用户的邮箱,用于找回密码时或登录时

11

email_state

smallint

5

0

N

N

0

邮箱认证:[0,1](0未认证|1审核中|2已认证)

12

avatar

varchar

255

0

Y

N

头像地址:[0,255]

13

open_id

varchar

255

0

Y

N

针对获取用户信息字段

14

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

15

vip_level

varchar

255

0

Y

N

会员等级

16

vip_discount

double

11

2

Y

N

0.00

会员折扣

表user_group (用户组:用于用户前端身份和鉴权)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

group_id

mediumint

8

0

N

Y

用户组ID:[0,8388607]

2

display

smallint

5

0

N

N

100

显示顺序:[0,1000]

3

name

varchar

16

0

N

N

名称:[0,16]

4

description

varchar

255

0

Y

N

描述:[0,255]描述该用户组的特点或权限范围

5

source_table

varchar

255

0

Y

N

来源表:

6

source_field

varchar

255

0

Y

N

来源字段:

7

source_id

int

10

0

N

N

0

来源ID:

8

register

smallint

5

0

Y

N

0

注册位置:

9

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

10

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表worker_users (工人用户)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

worker_users_id

int

10

0

N

Y

工人用户ID

2

worker_name

varchar

64

0

Y

N

工人姓名

3

worker_gender

varchar

64

0

Y

N

工人性别

4

work_id

varchar

64

0

N

N

工作证件

5

examine_state

varchar

16

0

N

N

未审核

审核状态

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.1 注册登录模块

(1)用户注册界面

游客点击首页右下角“我的”进入页面后点击“登录”进入登录页面,点击下方的“没有账户?马上注册”进入注册页面填写账号、密码、确认密码、昵称、邮箱、身份等信息后点击“立即注册”按钮,小程序会对输入的信息进行验证,验证通过后即可完成注册,其中工人用户注册后需要由管理员在后台管理端审核通过后方可使用。其主界面展示如下图4-1所示。

图4-1 用户注册界面图

用户注册的关键代码如下:

   Register.prototype.index = async function(ctx) {

var group_list = await $.services["user_group"].get_list({}, Object.assign({}, this.config));

return await ctx.render(this.config.tpl + "index.html", {

group_list

});

};

Register.prototype.api = async function(ctx) {

var user = $.services.user;

var body = ctx.request.body;

var username = body.username;

var obj = await user.get_obj({

username

});

if (obj) {

return {

error: {

code: 70000,

message: "账户名已存在",

},

};

} else {

var password = md5(body.password);

var nickname = body.nickname;

var user_group = body.user_group;

var email = body.email;

var email_state= body.hasOwnProperty('email_state') ? body.email_state : 0;

var phone = body.phone;

var phone_state= body.hasOwnProperty('phone_state') ? body.phone_state : 0;

var avatar = body.avatar;

var bl_reg = await user.add({

username,

password,

nickname,

user_group,

email,

email_state,

phone,

phone_state,

avatar

});

if (bl_reg) {

return {

result: "注册成功"

};

} else {

return {

error: {

code: 70000,

message: "注册失败",

},

};

}

}

};   

(2)用户登录界面

用户注册后可以通过自己的账户名和密码进行登录小程序,点击首页右下角“我的”进入页面后点击“登录”进入登录页面填写账号密码,小程序会对输入的信息进行验证,验证通过后即可完成登录,其界面展示如下图4-2所示。

图4-2 用户登录界面图

用户登录关键代码如下:

      const md5 = require("md5");

var Controller = require("../core/controller.js");

class Login extends Controller {

constructor(config) {

super(

Object.assign({

tpl: "./login/",

service: "user",

},

config

)

);

}

}

Login.prototype.api = async function(ctx) {

var body = ctx.request.body;

var obj = await $.services["user"].get_obj({

username: body.username

},{like:false});

if (obj) {

var group = await $.services["user_group"].get_obj({

name:obj.user_group

})

if (group){

if (group.name!=="管理员"){

var sql = "select examine_state from "+ group.source_table +" WHERE user_id = " + obj.user_id;

var userExamine = await $.mysql.run(sql);

if (userExamine && userExamine.length > 0 && userExamine[0].examine_state!=="已通过"){

return {

error: {

code: 70000,

message: "该用户审核未通过"

},

};

}

}

if (obj.state!==1){

return {

error: {

code: 70000,

message: "用户非可用状态,不能登录"

},

};

}

var password = md5(body.password);

if (password === obj.password) {

ctx.session.user = obj;

var date = Date.parse(new Date());

var token = md5(obj.user_id + "_" + date);

await $.services["access_token"].add({

token,

info: JSON.stringify(obj),

user_id:obj.user_id

});

obj.token = token;

return {

result: {obj}

};

} else {

return {

error: {

code: 70000,

message: "密码错误"

},

};

}

}else {

return {

error: {

code: 70000,

message: "用户组不存在"

},  

       };

}

} else {

return {

error: {

code: 70000,

message: "账户不存在"

}

};

}

};

4.1.2 客户用户功能模块

(1)首页界面

在微信端首页,用户可以查看首页展示的轮播图、装修案例、装修资讯、需求信息等内容。点击“装修案例”可以查看装修案例列表中某一案例的详情并进行点赞;点击“需求信息”可以查看需求信息列表中某一信息详情并进行点赞、收藏和发表评论操作。其界面如下图4-3所示。

图4-3首页界面图

(2)在线互动界面

用户可以查看在线互动列表中某个帖子的详情信息并可以进行点赞、收藏和发表评论操作,用户也可以发布论坛内容。其界面如下图4-4所示。

图4-4在线互动界面图

(3)装修资讯界面

用户可以查看装修资讯列表中某一资讯详情并进行点赞、收藏和发表评论操作,其界面如下图4-5所示。

图4-5装修资讯界面图

(4)我的界面

用户可以查看和管理我的页面中的基本信息、收藏、需求信息、接单信息和论坛管理信息。例如对基本信息进行修改;对需求信息进行查询、添加和重置操作;可以查看接单信息列表中某一信息详情并进行审核和回复,对已审核的订单可以完成在线支付操作等。其界面如图4-6所示。

图4-6 我的界面图

(5)在线客服界面

用户点击首页右下方的女生头像可以进入在线客服聊天界面与客服进行沟通,其界面如图4-7所示。

图4-7 在线客服界面图

4.1.3 工人用户功能模块

(1)在线互动界面

用户可以查看在线互动列表中某个帖子的详情信息并可以进行点赞、收藏和发表评论操作,可以查看用户评论信息并进行回复。其界面如下图4-8所示:

图4-8 在线互动界面图

(2)我的界面

用户可以查看和管理我的界面中的基本信息、收藏、装修案例、接单信息和论坛管理信息。例如对基本信息进行修改;对装修案例信息进行添加、查询和重置操作;对接单信息进行查询和重置操作等。其界面如下图4-9所示:

图4-9我的界面图

4.2 Web管理端

4.2.1 系统用户界面

管理员可以对系统用户信息进行查询、重置、添加和删除操作,其界面如下图4-10所示。

图4-10系统用户界面图

添加的关键代码如下:

Controller.prototype.add = async function(ctx) {

var result = await this.service.add(ctx.request.body, this.config);

if (this.service.error) {

return {

error: this.service.error,

};

}

return {

result,

};

};

删除的关键代码如下:

Controller.prototype.del = async function(ctx) {

if (!Object.keys(ctx.query).length) {

return {

code: 30000,

message: "删除条件不能为空!",

};

}

var result = await this.service.del(ctx.request.query, this.config);

if (this.service.error) {

return {

error: this.service.error,

};

}

return {

result,

};

};

4.2.2装修类型管理界面

管理员可以查看装修类型列表中某一装修类型详情,可以对装修类型信息进行查询、重置、添加和删除操作,其界面如下图4-11所示。

图4-11装修类型管理界面图

4.2.3装修案例管理界面

管理员可以查看装修案例列表中某一案例详情和评论信息,可以对装修案例信息进行查询、重置、添加和删除操作,其界面如下图4-12所示。

图4-12装修案例管理界面图

4.2.4接单信息管理界面

管理员可以查看接单信息列表中信息详情,可以对接单信息进行查询、重置和删除操作,其界面如下图4-13所示。

图4-13接单信息界面图

4.2.5系统管理界面

管理员可以对系统轮播图信息进行查询、添加、重置和删除操作,其界面如下图4-14所示。

图4-14系统管理界面图

4.2.6系统公告管理界面

管理员可以系统公告信息进行查询、添加、重置和删除操作,其界面如下图4-15所示。

图4-15系统公告管理界面图

4.2.7资源管理界面

管理员可以查看装修资讯列表中某一资讯详情和评论信息,可以对装修资讯、分类列表信息进行查询、添加、重置和删除操作,其界面如下图4-16所示。

图4-16资源管理界面图

4.2.8交流管理界面

管理员可以查看在线互动列表中某一信息详情和评论信息,可以对在线互动、分类列表信息进行查询、重置、添加和删除操作,其界面如下图4-17所示。

图4-17交流管理界面图

5系统测试

5.1 系统测试目的

无论什么样的系统,测试都至关重要,通过测试可以检查出潜藏的缺陷,从而确保系统的性能和稳定性,避免Bug的出现,并确保系统的功能和性价比达到预期的要求。

5.2系统测试用例

系统测试包括:用户登录功能测试、装修资讯查看功能、轮播图信息添加功能、密码修改功能测试,如表5-1、5-2、5-3、5-4所示:

用户登录功能测试:

表5-1 用户登录功能测试表

用例名称

用户登录系统

目的

测试用户通过正确的用户名和密码可否登录功能

前提

未登录的情况下

测试流程

1) 进入登录页面

2) 输入正确的用户名和密码

预期结果

用户名和密码正确的时候,跳转到登录成功界面,反之则显示错误信息,提示重新输入

实际结果

实际结果与预期结果一致

装修资讯查看功能测试:

表5-2 装修资讯查看功能测试表

用例名称

装修资讯查看

目的

测试装修资讯查看功能

前提

客户用户登录

测试流程

点击装修资讯

预期结果

可以查看到所有装修资讯信息

实际结果

实际结果与预期结果一致

轮播图信息添加界面测试:

表5-3 轮播图信息添加界面测试表

用例名称

轮播图信息添加测试用例

目的

测试轮播图信息添加功能

前提

管理员用户正常登录情况下

测试流程

1)管理员点击系统管理下方的轮播图管理,然后点击添加进入添加页面填写信息。

2)填写完毕后点击进行提交。

预期结果

提交以后,页面首页会显示新的轮播图信息 

实际结果

实际结果与预期结果一致

密码修改功能测试:

表5-4 密码修改功能测试表

用例名称

密码修改测试用例

目的

测试管理员密码修改功能

前提

管理员用户正常登录情况下

测试流程

1)管理员密码修改并完成填写。

2)点击进行提交。

预期结果

使用新的密码可以登录

实际结果

实际结果与预期结果一致

5.3 系统测试结果

通过编写装修接单小程序序的测试用例,已经检测完毕用户登录功能测试、装修资讯查看功能、轮播图信息添加功能、密码修改功能测试,通过这五大模块的测试为装修接单小程序序的后期推广运营提供了强力的技术支撑。

6 结论

在装修接单小程序开发之前,需要先对用户的具体需求进行分析。包括系统的可行性分析、功能需求分析以及其他需求等。在可行性分析过程中,对系统实现的技术性、经济性等方面进行了分析。总体上证明了系统实施的可行性。

本文总结了装修接单小程序开发背景与意义,然后阐述了系统的具体业务需求,并根据系统需求对系统结构以及功能模块等进行了详细地设计,将整个系统划分为多个不同的功能模块。在分析系统功能需求时,对整个系统的角色用例、功能模块等进行了分析,并选择合适的系统开发技术完成了对各个模块的开发工作。系统开发完成之后进行了部署,同时进行了系统的测试过程,通过测试证明了装修接单小程序在功能以及性能等方面都达到了预期的要求,具有较高的稳定性与可靠性。

参考文献

[1]陈淼,羊开云.基于微信小程序的校园报修管理系统设计[J].网络安全技术与应用,2024,(01):57-60.

[2]Wu J ,Chen N ,Xia H , et al.Design and development of the intelligent voice recognition‐based cognitive assessment WeChat mini‐program[J].Alzheimer's  Dementia,2023,19(S11):

[3]余霆.建筑装饰装修工程管理问题与对策研究[J].房地产世界,2023,(24):88-90.

[4]卢诗瑶,蔡士东,龙新宇等.基于微信小程序的智能温控系统设计[J].山西电子技术,2023,(06):26-28.

[5]张俊,赵玲艺.基于微信小程序的泰语词汇记忆平台设计与实现[J].Journal of Education and Teaching,2023,1(3):

[6]Yong R ,Feng P .Design and Realization of University Personnel Office Service Platform Based on WeChat Applet[J].Advances in Computer, Signals and Systems,2023,7(6):

[7]聂梦瑶,室内外装修施工合同在线管理平台V1.0.河南省,三门峡市艺尚轩装饰工程有限公司,2022-07-28.

[8]刘芳.大数据时代装修公司业务管理系统的开发[J].邯郸职业技术学院学报,2022,35(02):33-39+67.

[9]闵亮,薛格格,张玉欣等.基于Node.JS博客系统的设计与实现[J].电子设计工程,2022,30(07):37-41.

[10]安润泽,王旭辉.基于微信小程序的装修服务平台设计与实现[J].软件,2021,42(11):71-73.

[11]朱治国,家庭装修招投标信息管理平台V1.0.河南省,郑州象北云信息技术有限公司,2021-09-28.

[12]邢为平.基于层次分析法的安装工单系统的设计与实现[D].南京大学,2021.

[13]李律秀,张子沐,张朝阳等.自定义在线家居装修前景研究[J].居舍,2020,(27):25-26.

[14]王晴晴,吴丽萍,吴玉春等.基于互联网+装修平台的分析与设计[J].物联网技术,2020,10(06):64-66.

[15]何彪,好房购房地产广告代理在线接单系统V1.0.湖南省,湘潭好房购网络科技有限公司,2020-06-11.

[16]文政健,艺源装修管理系统V1.0.广西壮族自治区,广西建辰网络科技有限公司,2019-12-11.

[17]费晓明,吴文娟,陈芳芳.“一口接单”服务平台的探索与实践[J].湖州师范学院学报,2014,36(S1):190-193.

[18]Tyson M .Intro to Hapi: The Node.js framework[J].InfoWorld.com,2023,

[19]赵停停.基于MySQL数据库技术的Web动态网页设计研究[J].信息与电脑(理论版),2023,35(17):174-176.

[20]Heller M .What is Node.js? The JavaScript runtimeexplained [J]. InfoWorld. com,2022,

致  谢

在我完成这篇学术论文之际,我怀着无比感激的心情,向那些在我学术旅程中给予无私帮助的人们致以最深的谢意。首先,我要向我的论文导师表达最诚挚的感谢在整个论文的撰写过程中,导师以其博学和敏锐的洞察力,为我提供了无价的指导与支持。每一次深入的讨论,每一条精辟的评论,都是我前进路上的明灯,照亮了我探索知识的途程。导师不仅以其严谨的学术态度和敬业精神为我树立了榜样,更以其卓越的教学能力激励我不断追求卓越,我未来的人生篇章和学术成就产生了不可估量的影响。

此外,我还要感谢我的同学们,他们不仅是我的同窗好友,更是我学习生活中的重要。你们的陪伴和支持,让我的大学时光充满了温馨和力量。每一堂课上的思想碰撞,每一次项目中的团队协作,都是我宝贵的财富。感谢在学业上给予我助力的老师和同学们,是你们的鼓励和帮助,让我保持了前进的动力。

我亦不能忘记我的父母,是他们用无尽的爱心和,培育了我成长。你们的恩情,我将永远铭记在心。我承诺,将以实际行动和未来的成就来报答你们的养育之恩。在成长的道路上,我将不懈努力,不负众望,用我的成绩来回应你们对我的期望。

免费领取项目源码,请关注❥点赞收藏并私信博主,谢谢~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值