基于微信小程序宁德文旅平台的设计与实现---附源码89871

摘要

   在数字化和移动互联网浪潮的推动下,微信小程序以其低门槛、高效率和优秀的用户体验,成为了连接用户与服务的新桥梁。特别是在文化和旅游领域,微信小程序为游客提供了从行程规划到现场体验的全方位服务,极大地提升了旅游行业的服务质量和效率。

   宁德市,作为福建省的一个重要旅游目的地,以其独特的自然风光和深厚的文化底蕴吸引着大量的游客。然而,传统的旅游服务模式已无法满足现代游客对便捷性、个性化和智能化的需求。因此,基于微信小程序开发一款适合宁德市文化和旅游服务的应用平台,成为了提升宁德旅游竞争力、优化游客体验的关键。

   PHP作为一种成熟、稳定且广泛应用的服务器端编程语言,具有强大的开发能力和广泛的应用场景。在构建微信小程序后端服务时,PHP能够高效处理数据、保障系统稳定性,并提供丰富的API接口,与前端小程序实现无缝对接。

   通过本文的阐述,期望能够为基于PHP的微信小程序开发提供实践指导,同时推动宁德市文化和旅游服务的数字化、智能化升级,为游客带来更加便捷、高效和个性化的旅游体验。

关键词:宁德文旅平台,PHP,微信小程序;

Design and Implementation of Ningde Cultural and Tourism Platform Based on WeChat Mini Program

abstract

Driven by the wave of digital and mobile Internet, WeChat applet has become a new bridge connecting users and services with its low threshold, high efficiency and excellent user experience. Especially in the fields of culture and tourism, WeChat mini programs provide tourists with comprehensive services from itinerary planning to on-site experience, greatly improving the service quality and efficiency of the tourism industry.

Ningde City, as an important tourist destination in Fujian Province, attracts a large number of tourists with its unique natural scenery and profound cultural heritage. However, traditional tourism service models can no longer meet the needs of modern tourists for convenience, personalization, and intelligence. Therefore, developing an application platform suitable for cultural and tourism services in Ningde City based on WeChat mini programs has become the key to enhancing Ningde's tourism competitiveness and optimizing the tourist experience.

PHP, as a mature, stable, and widely used server-side programming language, has strong development capabilities and a wide range of application scenarios. When building the backend service for WeChat mini programs, PHP can efficiently process data, ensure system stability, and provide rich API interfaces to seamlessly integrate with the front-end mini program.

Through the explanation in this article, it is expected to provide practical guidance for the development of WeChat mini programs based on PHP, while promoting the digital and intelligent upgrading of cultural and tourism services in Ningde City, and bringing more convenient, efficient, and personalized travel experiences to tourists.

Keywords:Ningde Culture and Tourism Platform, PHP, WeChat Mini Program;

目录

第1章 绪   论

1.1选题背景和意义

1.2研究内容

1.3研究方法

1.4 开发技术

第2章 系统分析

2.1 可行性分析

2.1.1技术可行性

2.1.2经济可行性

2.1.3社会可行性

2.2总体设计原则

2.3 系统需求分析

2.4 系统用例分析

2.5 业务流程分析

2.5.1登录流程

2.5.2注册流程

2.5.3添加信息流程

2.5.4删除信息流程

第3章 系统设计

3.1 系统概要设计

3.2系统结构设计

3.3 数据库设计

3.3.1概念结构设计

3.3.2数据库表设计

第4章系统实现

4.1 客户端

4.1.1 用户注册界面

4.1.2 用户登录界面

4.1.3 旅游景点界面

4.1.4 修改密码界面

4.1.5 交流社区界面

4.2管理端

4.2.1 系统用户界面

4.2.2旅游景点管理界面

4.2.3购买订单管理界面

4.2.4系统管理界面

4.2.5通知公告管理界面

4.2.6资源管理界面

第5章软件测试

5.1软件测试的重要性

5.2测试实例的研究与选择

5.3测试环境与测试条件

5.4系统运行情况

5.5系统评价

5.5.1系统功能评价

5.5.2系统技术评价

5.5.3系统经济评价

第6章 总结

参考文献

致   谢

第一章   绪   论

1.1选题背景和意义

在数字化和移动互联网高速发展的今天,微信小程序作为一种轻量级、易传播的应用程序,已经成为连接用户与服务的重要桥梁。它凭借即用即走、无需安装、便于分享的特点,迅速在各个领域得到了广泛应用。特别是在旅游领域,微信小程序以其独特的优势,为游客提供了更加便捷、个性化的旅游服务体验。

宁德市作为福建省的一个重要旅游目的地,拥有丰富的自然和人文旅游资源,吸引了大量游客前来观光和体验。然而,传统的旅游服务模式已经难以满足现代游客对便捷性、个性化和智能化的需求。因此,借助微信小程序开发一款适合宁德市文化和旅游服务的应用平台,具有重要的现实意义和发展前景。基于微信小程序的宁德文旅平台可以为游客提供更加便捷、个性化的旅游服务。游客可以通过平台快速获取旅游信息、预订门票、查看旅游攻略等,从而更加轻松地规划和享受旅游行程。同时,平台还可以根据游客的兴趣和需求,提供个性化的推荐和服务,提升游客的旅游体验。基于微信小程序的宁德文旅平台还可以促进宁德市旅游业的数字化和智能化升级。通过平台的数据分析和用户反馈,宁德市旅游部门和企业可以更加精准地了解游客的需求和偏好,优化旅游产品和服务,提升旅游业的竞争力和可持续发展能力。

基于微信小程序的宁德文旅平台还具有广阔的市场前景和商业价值。随着移动互联网的普及和用户对旅游服务的需求不断增长,该平台有望吸引大量用户和商家入驻,形成良性循环的生态系统。同时,平台还可以为商家提供精准营销和推广渠道,促进旅游业和相关产业的融合发展。

基于微信小程序的宁德文旅平台的设计与实现具有重要的选题背景和意义。它不仅可以为游客提供更加便捷、个性化的旅游服务体验,促进宁德市旅游业的数字化和智能化升级,还具有广阔的市场前景和商业价值。因此,该课题的研究和实现具有重要的现实意义和长远的发展潜力。

1.2研究内容

在设计与实现基于微信小程序的宁德文旅平台时,深入研究并实施了多个核心功能模块。首先,景点类型管理模块允许平台对不同类型的景点进行分类和标识,从而为用户提供更加精准的景点推荐。旅游景点管理模块则详细展示了各个景点的信息,包括景点介绍、图片展示、开放时间等,为用户提供全面的景点信息。

购票订单管理模块是平台的重要组成部分,它允许用户在线购买景点门票,并实时跟踪订单状态,确保用户能够顺利获取门票。交流板块管理和交流社区管理模块为用户提供了互动交流的平台,用户可以在这里分享旅行经验、提问解答,增强了用户的参与感和社区归属感。

系统管理模块中的轮播图功能,用于在平台首页展示重要的信息或推广内容,吸引用户的注意力。通知公告管理模块则用于发布平台的重要通知和公告,确保用户能够及时了解平台动态。资源管理模块涵盖了旅游攻略和攻略分类,为用户提供丰富的旅行指南和建议,帮助用户更好地规划行程。

这些研究内容的实施,旨在为用户打造一个功能完善、交互友好、服务贴心的文旅平台,全面提升用户在宁德的旅游体验。

1.3研究方法

首先,通过引擎搜索或者查阅相关文献资料,了解了本系统开发的背景以及设计系统的意义所在,收集用户需求信息。其次,在开发工具上,最终确定是基于Mysql数据库,在PHP设计的基础上实现,设计出系统大致的功能模块。主要从方便系统用户和系统管理员的角度进行分析,明确该系统应该具有的功能。最终是测试系统,通过用例测试发现存在的问题并找到解决的方案。利用现有的开发平台,结合自己所学的知识,在老师的指导帮助下来完成该设计,确保系统的可用性、实用性。

1.4 开发技术

ThinkPHP是为了简化企业级应用开发和敏捷WEB应用开发而诞生的。最早诞生于2006年初,2007年元旦正式更名为ThinkPHP,并且遵循Apache2开源协议发布。ThinkPHP从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,也注重易用性。并且拥有众多原创功能和特性,在社区团队的积极参与下,在易用性、扩展性和性能方面不断优化和改进。

ThinkPHP是一个快速、兼容而且简单的轻量级国产PHP开发框架,诞生于2006年初,原名FCS,2007年元旦正式更名为ThinkPHP,遵循Apache2开源协议发布,从Struts结构移植过来并做了改进和完善,同时也借鉴了国外很多优秀的框架和模式,使用面向对象的开发结构和MVC模式,融合了Struts的思想和TagLib(标签库)、RoR的ORM映射和ActiveRecord模式。

PHP采用函数或者过程来解析对于数据的操作,但又把数据和函数之间相互分开,这样并不利于维护,并会增加程序的工作量。而面向对象的编程将程序的函数和函数对于数据的操作封装在一个类中,作为一个整体来处理。所以PHP语言是主要通过面向对象来实现编程,并且摒除了C++语言中的指针、多继承等比较难理解部分,创造出了自身独有的单继承、多接口、高内聚、低耦合等特性。

PHP技术对动态Web页面的开发作用简直是举足轻重。可以很快的响应到客户端的发送请求。是甲骨文公司旗下的IT及互联网技术服务公司Sun Microsystems公司主导并创立的动态网页技术的标准。而且能依据请求内容动态地生成XML、HTML,为用户的网络请求提供技术服务,而且可以与服务器上的其它PHP程序共同处理先对复杂的业务需求。

PHP主要优势如下:(1)一旦程序有一次成功的编写,就能在多处运行起来。(2)支持面特别广,许多平台已经引入该技术。

第二章  系统分析

2.1 可行性分析

可行性分析的目的是确定一个系统是否有必要开发、确定系统是否能以最小的代价实现。其工作主要有三个方面,分别是技术、经济和社会三方面的可行性。会从这三个方面对基于微信小程序宁德文旅平台的设计与实现进行详细的分析。

2.1.1技术可行性

PHP作为一种成熟、稳定的服务器端编程语言,广泛应用于Web开发领域,具有强大的数据处理能力和丰富的开发资源。同时,微信小程序作为一种轻量级的应用程序,具有广泛的用户基础和良好的用户体验。结合PHP与微信小程序开发宁德文旅平台,技术上是完全可行的。PHP可以构建稳定、高效的后端服务,处理数据、提供API接口,并与微信小程序前端实现无缝对接。微信小程序则可以为游客提供便捷、直观的操作界面和个性化的旅游服务体验。因此,利用PHP和微信小程序开发宁德文旅平台,不仅能够满足现代游客对旅游服务的需求,还能够实现技术上的优化和创新。

2.1.2经济可行性

本系统设计所选择的开发工具和服务器都是免费的开源软件,又或者是适合用户使用的免费版本,并不需要支付费用,而且由作者本人单独完成,也不存在团队费用,几乎没有经济成本,具备经济可行性。

2.1.3社会可行性

社会可行性主要包括法律和用户两个方面,下面将从这两方面进行分析。

(1)法律因素

本系统是学习开发所制作的程序,并不用作商业用途,是在根据实际调研的结果结合现有的旅游平台得出的,而且系统制作的全部过程都是在个人的工作电脑中完成的,使用的都是开源和免费的开发环境、分析软件和数据库,不存在侵权问题。

(2)用户可行性

微信小程序作为一种普及率高、使用门槛低的应用程序,已经成为用户日常生活的一部分。基于微信小程序开发的宁德文旅平台,用户无需额外安装应用,即可通过微信直接访问和使用,极大地提高了用户的使用便利性。同时,平台界面设计直观友好,功能操作简便易懂,即使是对于不熟悉旅游服务的用户也能快速上手。因此,从用户角度来看,该平台的设计与实施是完全可行的,能够满足广大游客对便捷、高效旅游服务的需求。

2.2总体设计原则

一个系统要在开发和维护的过程中方便使用,必须采取一定的设计原则,其主要设计原则有:

简单性:系统功能简单易懂,只需要掌握基本的计算机操作能力即可使用。

针对性:针对特定的用户,没有多余的其他功能,使用户可以专心使用。

实用性:能够满足用户查看旅游攻略、旅游景点、交流社区、网站公告、购票订单、交流社区等方面的需求。

先进性:本系统的代码采用读取数据的方式,方便后续开发、拓展。

2.3 系统需求分析

基于微信小程序宁德文旅平台的设计与实现需要满足的需求有以下几个:

1.信息获取方便,用户可在网页上快速浏览到新的信息。

2.查看旅游攻略、旅游景点、交流社区、网站公告、购票订单、交流社区等。

3.注册登录,需要吸引用户,即通过注册来提高用户的存留率。

4.修改用户信息,可以修改用户密码或者用户名等一些个性化操作。

5.管理员功能,管理员可以对景点类型管理、旅游景点管理、购票订单管理、交流板块管理、交流社区管理、系统管理、通知公告管理、资源管理等进行管理。

6.系统安全,操作简便,不过于复杂。

7.系统可以稳定运行,不存在卡顿等问题造成用户反感。

2.4 系统用例分析

系统的用例展示的是系统功能与用户之间的关系,通过用例的方式能够直观的展示出来,本基于微信小程序宁德文旅平台的设计与实现的完整UML用例图分别是图2-1、图2-2。

图2-1 基于微信小程序宁德文旅平台的设计与实现普通用户角色用例图

图2-2 基于微信小程序宁德文旅平台的设计与实现管理员角色用

2.5 业务流程分析

2.5.1登录流程

登录模块主要满足管理员以及用户的权限登录,用户登录流程图如图2-3所示。

图2-3登录流程图

2.5.2注册流程

未有账号的用户可进入注册界面进行注册操作,用户注册流程图如图2-4所示。

图2-4注册流程图

2.5.3添加信息流程

用户在添加信息时,信息编号自动生成,系统会对添加的信息进行验证,验证通过则添加至数据库,添加信息成功,反之添加失败。添加信息流程如图2-5所示。

图2-5添加信息流程图

2.5.4删除信息流程

用户可选择要删除的信息进行信息删除操作,在删除信息时系统提示是否确定删除信息,是则删除信息成功,系统数据库将信息进行删除。删除信息流程图如图2-6所示。

图2-6删除信息流程图

第三章  系统设计

3.1 系统概要设计

本基于微信小程序宁德文旅平台的设计与实现选择B/S结构(Browser/Server,浏览器/服务器结构)和基于Web服务两种模式。适合在互联网上进行操作,只要用户能连网,任何时间、任何地点都可以进行系统的操作使用。系统工作原理图如图3-1所示:

图3-1 系统工作原理图

3.2系统结构设计

整个系统是由多个功能模块组合而成的,要将所有的功能模块都一一列举出来,然后进行逐个的功能设计,使得每一个模块都有相对应的功能设计,然后进行系统整体的设计。

基于微信小程序宁德文旅平台的设计与实现结构图如图3-2所示。

图3-2 基于微信小程序宁德文旅平台的设计与实现结构图

3.3 数据库设计

数据库可以说是所有软件的根本,如果数据库存在缺陷,那么会导致系统开发的不顺利、维护困难、用户使用不顺畅等一系列问题,严重时将会直接损害企业的利益,同时在开发完成后,数据库缺陷也更加难以解决。所以必须要对数据库设计重点把握,做到认真细致。因此,数据库设计是这个基于微信小程序宁德文旅平台的设计与实现的重点要素。

3.3.1概念结构设计

基于微信小程序宁德文旅平台的设计与实现总E-R图如下图3-3所示

图3-3基于微信小程序宁德文旅平台的设计与实现总E-R图

3.3.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:

表communication_community (交流社区)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

communication_community_id

int

10

0

N

Y

交流社区ID

2

post_title

varchar

64

0

Y

N

帖子标题

3

communication_section

varchar

64

0

Y

N

交流板块

4

publish_users

int

10

0

Y

N

0

发布用户

5

tourist_attractions

varchar

64

0

Y

N

旅游景点

6

share_pictures

varchar

255

0

Y

N

分享图片

7

share_videos

varchar

255

0

Y

N

分享视频

8

post_body

text

65535

0

Y

N

帖子正文

9

hits

int

10

0

N

N

0

点击数

10

praise_len

int

10

0

N

N

0

点赞数

11

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

12

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表communication_section (交流板块)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

communication_section_id

int

10

0

N

Y

交流板块ID

2

communication_section

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

更新时间

表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

更新时间:

表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已取消

表regular_users (普通用户)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

regular_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

user_phone_number

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

更新时间

表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

更新时间:

表ticket_purchase_order (购票订单)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

ticket_purchase_order_id

int

10

0

N

Y

购票订单ID

2

attraction_name

varchar

64

0

Y

N

景点名称

3

scenic_area

varchar

64

0

Y

N

景点地区

4

detailed_address

varchar

64

0

Y

N

详细地址

5

attraction_tickets

int

10

0

Y

N

0

景点门票

6

number_of_tickets_purchased

int

10

0

Y

N

0

购票数量

7

total_price

varchar

64

0

Y

N

合计总价

8

ordinary_users

int

10

0

Y

N

0

普通用户

9

user_name

varchar

64

0

Y

N

用户姓名

10

pay_state

varchar

16

0

N

N

未支付

支付状态

11

pay_type

varchar

16

0

Y

N

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

12

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

13

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表tourist_attractions (旅游景点)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

tourist_attractions_id

int

10

0

N

Y

旅游景点ID

2

attraction_name

varchar

64

0

Y

N

景点名称

3

types_of_attractions

varchar

64

0

Y

N

景点类型

4

scenic_area

varchar

64

0

Y

N

景点地区

5

detailed_address

varchar

64

0

Y

N

详细地址

6

best_season

varchar

64

0

Y

N

最佳季节

7

attraction_tickets

int

10

0

Y

N

0

景点门票

8

scenic_spot_pictures

varchar

255

0

Y

N

景点图片

9

nearby_hotels

text

65535

0

Y

N

附近酒店

10

introduction_to_scenic_spots

text

65535

0

Y

N

景点简介

11

guide_to_scenic_spots

text

65535

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

更新时间

表types_of_attractions (景点类型)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

types_of_attractions_id

int

10

0

N

Y

景点类型ID

2

types_of_attractions

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

更新时间

表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

更新时间:

第4章系统实现

4.1 客户端

4.1.1 用户注册界面

不是基于微信小程序的红色旅游分享平台的用户可以通过微信小程序在线进行注册,填写上自己的账号、密码、重复密码、昵称、邮箱等信息后点击“提交”按钮后将会验证是否有非空数据,再验证密码和重复密码是否一样,最后验证是否账号重复,都验证没问题后即可注册成功。用户注册界面展示如下

图4-1用户注册界面图

注册的关键代码如下:

public function register()

    {

        if (Request::isPost()) {

            $request = Request::param();

            $request['create_time'] = isset($request['create_time']) ? $request['create_time'] : date('Y-m-d H:i:s'

            $result = $this->validate($request, $this->validate);

            if (true !== $result) {

                $data['error'] = 30000;

                $data['message'] = $result;

            } else {

                $request['password'] = md5($request['password']);

                $result = $this->model->register($request, $this->table);

                $data = $result;

            }

        } else {

            $data['error'] = 30000;

            $data['message'] = "field的值不能为空!";

        }

        return json_encode($data);

    }

public function register($request=[],$table_name = ''){

        $username = $request['username'];

        $bol = $this->where(['username'=>$username])->find();

        if (!$bol){

            $result = self::allowField(true)->save($request);

            if ($result) {

                return ['result' => 1];

            } else {

                return ['error' => ['code' => 3000, 'message' => '注册失败']];

            }

        }else{

            return ['error' => ['code' => 3000, 'message' => '注册失败,账号已存在']];

        }

    }

4.1.2 用户登录界面

微信小程序上注册后的用户可以通过自己的用户名和密码进行登录,在用户填写好自己的用户名和密码信息并点击“登录”按钮后,将会先验证是否有非空数据,再验证填写的用户信息和数据库中保存的是否一致,一致后将会登录成功,登录成功后将会在左上角上显示用户信息;否则将会提示相应错误信息,用户登录界面如下图4-2所示。

图4-2用户登录界面图

登录的关键代码如下:

public function login()

    {

        if (Request::isPost()) {

            $request = Request::param();

            $result = $this->validate($request, $this->validate);

            if (true !== $result) {

                $data['error'] = 30000;

                $data['message'] = $result;

            } else {

                $request['password'] = md5($request['password']);

                $result = $this->model->login($request, $this->table);

                $data = $result;

            }

        } else {

            $data['error'] = 30000;

            $data['message'] = "field的值不能为空!";

        }

        return json_encode($data);

    }

public function login($request=[],$table_name = ''){

        $username = $request['username'];

        $password = $request['password'];

        $bol = $this->where(['username'=>$username])->find();

        if ($bol){

            $password = md5($password);

            if ($request['password']==$bol['password']) {

                //添加token信息

                $access_token['create_time'] = date('Y-m-d H:i:s');

                $access_token['update_time'] = date('Y-m-d H:i:s');

$access_token['info'] = json_encode($bol);

                // $access_token['info'] = $bol;

                $access_token['token'] = md5(date('Y-m-d H:i:s'));

                $bol_token = Db::name('AccessToken')->insert($access_token);

                if ($bol_token){

                    $data['obj'] = $bol;

                    $data['obj']['token'] = $access_token['token'];

                    return ['result' => $data];

                }else{

                    return ['error' => ['code' => 5000, 'message' => '登录失败,token生成失败']];

                }

            } else {

                return ['error' => ['code' => 5000, 'message' => '登录失败,密码不正确']];

            }

        }else{

            return ['error' => ['code' => 5000, 'message' => '登录失败,账号不存在']];

        }

    }

输入有效的用户名和密码信息,点击“登录”按钮,自动跳转到“首页”页面,首页界面如下图4-3所示。

图4-3首页界面图

4.1.3 旅游景点界面

点击“旅游景点”,普通用户可以浏览系统推荐的旅游景点,包括景点名称、景点分类等。界面如下图4-4所示。

图4-4旅游景点详情界面图

4.1.4 修改密码界面

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

图4-5密码修改界面图

4.1.5 交流社区界面

用户点击“交流社区”,可以在论坛内发布帖子、评论和互动,分享旅游经验和交流意见。界面如下图4-6所示。

图4-6交流社区界面图

4.2管理端

4.2.1 系统用户界面

管理员点击“系统用户”这一菜单会显示管理员、普通用户这两个子菜单,管理员可以对这两个角色的信息进行增删改查操作。界面如下图4-7所示。

图4-7系统用户管理界面图

添加的关键代码如下:

public function add()

    {

        if (Request::isPost()) {

            $request = Request::param();

            $request['create_time'] = isset($request['create_time']) ? $request['create_time'] : date('Y-m-d H:i:s');

            $request['update_time'] = isset($request['update_time']) ? $request['update_time'] : date('Y-m-d H:i:s');

            $result = $this->validate($request, $this->validate);

            if (true !== $result) {

                // 验证失败 输出错误信息

                $data['error'] = 30000;

                $data['message'] = $result;

            } else {

if($this->table == 'user'){

$request['password'] = md5($request['password']);

}

$res = $this->add_before($request, $this->table, $this->table_id);

if($res['code'] == 200){

$result = $this->model->add($request, $this->table, $this->table_id);

$this->add_after($this->table);

$data = $result;

}else{

$data['error'] = $res;

}

            }

        } else {

            $data['error']['code'] = 30000;

            $data['error']['message'] = "field的值不能为空!";

        }

        return json_encode($data);

    }

删除的关键代码如下:

public function del()

    {

        $request = Request::param();

        $result = $this->model->del_data($request, $this->table, $this->table_id);

        $data = $result;

        return json_encode($data);

    }

4.2.2旅游景点管理界面

管理员点击左边的“旅游景点管理”菜单后将可以对旅游景点进行管理,包括添加、编辑和删除旅游景点等,还可以查看和回复用户评论、查看评论信息等。旅游景点管理界面如下图4-8所示。

图4-8旅游景点列表界面图

图4-9旅游景点添加界面图

4.2.3购买订单管理界面

管理员点击后台左边的“购买订单管理”菜单后将可以对购买订单进行管理,包括添加、编辑和删除购买订单等。购买订单管理界面如下图4-10所示。

图4-10购买订单列表界面图

4.2.4系统管理界面

管理员点击“系统管理”这一菜单会显示轮播图这一个子菜单,管理员可以对前台展示的轮播图进行设置,界面如下图所示。

图4-11系统管理界面图

轮播图上传的关键代码如下:

public function upload()

    {

        $month = date('Ym', time());

        $data = 'file';

        $path = 'upload/file/' . $month . "/";//上传文件保存位置

        $allow_ext = explode(",", "jpg,jpeg,png,jfif,bmp,gif,ico,xls,xlsx,AVI,mov,rmvb,rm,FLV,mp4,3GP");

        if ($_FILES) {

            $file = $_FILES[$data];

            $rst = [];

            if (!empty($file['name'])) {

                $file_type = explode('.', $file['name']);

                $ext = end($file_type); //获取文件的格式

                $ext = strtolower($ext);

                if (!in_array($ext, $allow_ext)) {

                    $rst['error']['code'] = 30000;

                    $rst['message'] = '只能上传jpg,jpeg,png,jfif,bmp,gif,ico,xls,xlsx,AVI,mov,rmvb,rm,FLV,mp4,3GP类型文件';

                } else {

                    if (!is_dir($path))

                    {

                        mkdir($path, 0777, true);

                    };

                    $name = date('YmdHis') . '_' . rand(10000, 99999) . '.' . $ext;

                    $save_rst = move_uploaded_file($file['tmp_name'], $path . $name);

                    if ($save_rst !== false) {

                        $rst['result']['url'] = 'http://'.$_SERVER['HTTP_HOST'].'/'.$path . $name;

                    } else {

                        $rst['error']['code'] = 30000;

                        $rst['error']['message'] = '文件上传失败';

                    }

                }

            } else {

                $rst['error']['code'] = 30000;

                $rst['error']['message'] = '未选择文件';

            }

        } else {

            $rst['error']['code'] = 30000;

            $rst['error']['message'] = '未获取到文件';

        }

        return json_encode($rst);

    }

4.2.5通知公告管理界面

点击“通知公告管理”这个菜单,可以查看到系统中所有添加的通知公告,支持通过标题对通知公告进行查询,添加、删除等操作。通知公告管理界面如下图所示。

图4-12通知公告界面图

4.2.6资源管理界面

管理员点击“资源管理”这一菜单会显示旅游攻略、攻略分类这两个子菜单,管理员可以上传、编辑、删除新闻资讯,设置分类,同时可以查看和回复用户评论。界面如下图所示。

图4-13旅游攻略界面图

图4-14攻略分类界面图

第5章软件测试

测试存在于软件开发进程中的最后一个阶段,它可以保证一个软件的开发质量是否符合设计者的初衷,也为程序的正式上线做了最后一道质量检测的工序。软件测试主要是控制各种条件、包括软件输出方式,使用模式和运行环境等,来评估一个系统或应用是否符合设计标准。在软件测试过程中,我们一般刻意的去制造错误和极端条件,不能仅依照正常模式允许,而是多去尝试那些意外的情况。

5.1软件测试的重要性

只有在运行和维护阶段之前经历大量的测试的软件,才能说明它的质量是经得起检验的。最近计算机业界也都一致认为,测试应该存在于软件设计的每个阶段,因为越早发现错误,修复起来就越容易。

实际上,对于一个软件应用,错误是必然存在的,无论使用何种技术或手段,都不可能绝对的排除软件漏洞。测试是随着软件开发一同诞生的,两者是共同发展进步的。实际上,测试可以大幅度的降低维护的成本,如果一个漏洞在开发的早期就被发现,那么修复它的成本远比上线后再修复的成本要低得多。

5.2测试实例的研究与选择

测试有白盒测试和黑盒测试两种方式。

其中,白盒测试是将软件看成一个透明的白盒子,按照程序的内部控制结构和处理技术逻辑来选定测试用例、软件系统测试的逻辑路径及过程需要进行管理测试,又称玻璃盒测试。因此白盒测试需要选择足够多的测试用例,覆盖尽可能多的代码来发现程序中的错误。

黑盒测试,也称为功能测试。它将需软件看作一个黑盒,像一个普通用户一样来模拟软件的使用流程。黑盒测试通过大量的输入边界值或错误数据,来检查是否可产生正确的输出。

本系统测试 主要选择黑盒测试,少量采用白盒测试。通过测试达到以下测试目的:

1.检查各大功能模块的运行,确保其能够正确运行,并检查各页面的完整性,保证页面完整。

2.检查各个接口是否可以正确地输入和输出,保证数据流通稳定可行。

3.检查数据结构,保证其和外部接口没有访问错误,访问顺利。

4.检查原计划的性能需求有没有完成,运行流畅。

本系统的测试用例(部分):

登录部分测试用例

编号

对象

项目

操作

预期结果

结果

1

登录

登录提示

使用正确的账号密码登录

成功登录

预期结果

2

登录提示

使用正确的账号但错误的密码登录

提示密码错误

预期结果

3

登录提示

使用错误的账号登录

提示不存在账户

预期结果

4

登录提示

不输入账号,点击登录

提示输入账号

预期结果

5

登录提示

输入账号但不输入密码点击登录

提示输入密码

预期结果

6

登录入口

已登录账号,查看登录入口

不显示登录入口

预期结果

5.3测试环境与测试条件

处理器:Inter Core I7-4710MQ四核处理器

内存:4GB

硬盘:1T

操作系统:Windows 10

数据库:MySQL

5.4系统运行情况

全部测试用例都已通过(包括但不限于以上测试用例),且不存在漏洞,实现了论文开始时所作要求。本系统运行稳定,使用流畅,可以满足客户需求。

5.5系统评价

5.5.1系统功能评价

试运行后进行系统评估,可以认为该系统达到预定的目标要求,可以满足用户的需求,也满足了系统开发前所作目标。

5.5.2系统技术评价

系统在经过大量重复测试后运行十分稳定,安全实用,功能模块已经达到预定目标所需。

5.5.3系统经济评价

在规定的时间内实现系统的大部分功能,且满足要求,节省开发成本,有助于提高科学管理水平,符合本人经济情况。


第6章 总结

通过本文的研究和实践,我们成功地基于微信小程序框架设计并实现了一个宁德文旅平台。该平台具有稳定、高效、可靠的特点,通过合理的功能模块设计和前后端分离的架构,提供了良好的用户体验。在系统测试中,验证了系统的稳定性和功能完整性,表明基于微信小程序在快速开发和高质量软件构建方面具有显著优势。

本文的研究结果表明,使用基于微信小程序能够快速开发出高效可靠的宁德文旅平台。该平台通过合理的功能设计和良好的用户体验,提供了便捷的文旅平台服务,促进了资源的有效利用。同时,基于微信小程序的应用也为系统的开发和维护带来了便利。然而,本研究还存在一些不足之处,如对系统安全性和性能优化的考虑不够充分。未来的研究可以进一步完善系统的功能和性能,并探索其他技术和方法的应用,以进一步提升宁德文旅平台的质量和用户满意度。

参考文献

[1]黎明.基于云计算虚拟化技术的智慧旅游信息服务平台设计[J].佳木斯大学学报(自然科学版),2024,42(01):30-33+82.

[2]胡涵毅.基于PHP的校园资源共享平台设计与实现[J].现代信息科技,2023,7(23):1-5.DOI:10.19850/j.cnki.2096-4706.2023.23.001.

[3]赵潞,李婷,蒋凡凡.文旅融合背景下智慧文旅服务平台构建探究[J].旅游纵览,2023,(22):33-35.

[4]陕西文旅惠民平台简介[J].百花,2023,(11):2.

[5]何光凝,李常谦.北海旅游语言服务平台的设计与建设[J].信息与电脑(理论版),2023,35(21):100-103.

[6]陕西文旅惠民平台简介[J].百花,2023,(10):2.

[7]王明月.清明上河园智慧旅游平台设计思路[J].合作经济与科技,2023,(21):64-67.DOI:10.13665/j.cnki.hzjjykj.2023.21.007.

[8]Roda E ,Luca D F ,Priori C E , et al.The Designer Drug αPHP Affected Cell Proliferation and Triggered Deathly Mechanisms in Murine Neural Stem/Progenitor Cells[J].Biology,2023,12(9):

[9]Zhang L ,Li P ,Zhang T .Exploration of Learning-Centered Teaching Reform: Taking PHP Framework Technology as an Example[J].Advances in Educational Technology and Psychology,2023,7(10):

[10]Zhao C ,Tu T ,Wang C , et al.VulPathsFinder: A Static Method for Finding Vulnerable Paths in PHP Applications Based on CPG[J].Applied Sciences,2023,13(16):

[11]Ophir O ,Levy G ,Bar E , et al.Deletion ofGtf2ivia Systemic Administration of AAV-PHP.eB Virus Increases Social Behavior in a Mouse Model of a Neurodevelopmental Disorder[J].Biomedicines,2023,11(8):

[12]赵金库,赵光旭.智慧旅游数字化信息服务平台的建设与研究[J].通信与信息技术,2023,(04):20-23.

[13]余弦,龙杰丽,王二帅.在线旅游平台商家管理系统探析——以马蜂窝旅游网为例[J].西部旅游,2023,(14):79-81.

[14]Nadia F ,B J H ,S L B , et al.Heparin reversal with protamine sulfate after Percutaneous Hepatic Perfusion (PHP): is less more?[J].Cancer imaging : the official publication of the International Cancer Imaging Society,2023,23(1):68-68.

[15]刘艳春,张宗霞.基于PHP的动态网站设计与实现[J].集成电路应用,2023,40(07):238-239.DOI:10.19339/j.issn.1674-2583.2023.07.108.

[16]付函瑜.基于Linux实现的智能旅游规划平台[J].信息技术与信息化,2023,(07):199-202.

[17]王诗培.用好平台推动旅游教育迈上新台阶[N].中国旅游报,2023-06-06(007).DOI:10.28109/n.cnki.nclyb.2023.001371.

[18]张日花,刘婷婷,陈红娟.基于PHP+MySQL的在线相册设计与实现[J].现代信息科技,2023,7(07):15-19.DOI:10.19850/j.cnki.2096-4706.2023.07.004.

[19]张春燕,覃琼花,农铮等.基于PHP的创新创业教学网络平台设计与应用[J].现代信息科技,2023,7(04):105-108.DOI:10.19850/j.cnki.2096-4706.2023.04.027.

[20]蒋先梅.基于PHP的学生信息管理系统的设计与实现[J].无线互联科技,2023,20(01):45-47.

   谢

大学生活在这个时候即将划上一个句号,但是对于我的人生道路来说,这仅仅是一个逗号,我将面对的是又一次征程的开始。

回忆过去,许许多多的事情浮现在脑海:刚上大学时欢乐心情和兴奋的场景还历历在目。一切都是那么新鲜,那么富有吸引力。有快乐也有艰辛,有收获也有失落。衷心感谢学校所有支持帮助过我的老师,谢谢你们多年来的关心和爱护。同窗的友情同样难忘,你们与我共同走过了人生中不平凡的道路,给我留下了值得珍藏的美好记忆。

最后,我要特别感谢指导基于微信小程序宁德文旅平台的设计与实现设计的老师。本论文是在他的悉心指导和热情帮助下完成的,老师认真负责的工作态度,严谨的治学精神和精深的理论水平都使我受益匪浅。老师无论在理论上还是在实践中,都给予我很大的帮助,使我专业技能的应用水平得到很大提高,这对于我以后的工作和学习都有益处。值此论文完成之际,特别向老师表示衷心的感谢和崇高的敬意,谢谢他细心而又耐心地辅导,使得我得以顺利的完成毕业设计开发工作,同时也要感谢其他帮助过我的老师和同学,他们在我成长过程中给予了我很大的帮助,在此一并表示感谢。

由于本人水平有限,加上时间紧促,本文一定有不少缺点和不足,恳请各位老师给予帮助和指正。

点赞+收藏+关注  →私信领取本源代码、数据库

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值