计算机毕业设计必看必学!! 24602 PHP 民用无人机实名登记系统,原创定制程序, java、PHP、python、小程序、文案全套、毕设成品等

摘要

信息化社会内需要与之针对性的信息获取途径,但是途径的扩展基本上为人们所努力的方向,由于站在的角度存在偏差,人们经常能够获得不同类型信息,这也是技术最为难以攻克的课题。针对民用无人机实名登记系统等问题,对民用无人机实名登记系统进行研究分析,然后开发设计出民用无人机实名登记系统以解决问题。

民用无人机实名登记系统主要功能模块包括限飞区、市售无人机、无人机登记、飞行计划、用户处罚、厂商处罚、政策法规,采取面对对象的开发模式进行软件的开发和硬体的架设,能很好的满足实际使用的需求,完善了对应的软体架设以及程序编码的工作,采取Mysql作为后台数据的主要存储单元,采用PHP技术、Ajax技术进行业务系统的编码及其开发,实现了本系统的全部功能。本次报告,首先分析了研究的背景、作用、意义,为研究工作的合理性打下了基础。针对民用无人机实名登记系统的各项需求以及技术问题进行分析,证明了系统的必要性和技术可行性,然后对设计系统需要使用的技术软件以及设计思想做了基本的介绍,最后来实现民用无人机实名登记系统和部署运行使用它。

关键词:民用无人机实名登记系统  PHP  MySQL

Abstract

In the information society, there is a need for targeted information acquisition channels, but the expansion of channels is basically the direction of people's efforts. Due to the deviation in perspective, people often can obtain different types of information, which is also the most difficult topic for technology to overcome. Research and analyze the real name registration system for civil drones, and then develop and design a real name registration system for civil drones to solve the problem.

The main functional modules of the real name registration system for civil drones include restricted flight zones, commercial drones, drone registration, flight plans, user penalties, manufacturer penalties, policies and regulations. The system adopts an object-oriented development model for software development and hardware installation, which can meet the actual needs of use. It improves the corresponding software installation and program coding work, and adopts MySQL as the main storage unit for backend data, Adopting PHP and Ajax technologies for business system coding and development, all functions of this system have been achieved. This report first analyzes the background, role, and significance of the research, laying the foundation for the rationality of the research work. An analysis was conducted on the various requirements and technical issues of the real name registration system for civil drones, demonstrating the necessity and technical feasibility of the system. Then, a basic introduction was made to the technical software and design ideas required for designing the system. Finally, the implementation and deployment of the real name registration system for civil drones were carried out.

Keywords:Civil UAV Real Name Registration System PHP MySQL

  录

1 引言

1.1 研究背景

1.2 研究方法

1.3 ThinkPHP框架

1.4 Tomcat描述

1.5 论文结构安排 3

2 民用无人机实名登记系统的需求分析 4

2.1 系统可行性分析 4

2.1.1技术可行性分析 4

2.1.2经济可行性分析 4

2.1.3操作可行性分析 5

2.2 系统需求分析 5

2.2.1功能需求分析 5

2.2.2非功能性需求分析

2.3 系统用例分析

3 民用无人机实名登记系统总体设计

3.1系统功能模块设计

3.2数据库设计

3.2.1数据库概念结构设计

3.2.2数据库逻辑结构设计

4 关键模块的设计与实现

4.1用户功能模块

4.1.1前台首页界面

4.1.2注册界面

4.1.3登录界面 20

4.1.4我的账户界面

4.1.5新闻资讯界面

4.1.6限飞区界面

4.1.7市售无人机界面

4.2管理员功能角模块

4.2.1公共管理界面

4.2.2用户管理界面

4.2.3限飞区管理界面

4.2.4无人机登记管理界面 25

4.2.5飞行计划管理界面 25

5 系统测试 27

5.1 系统测试的目的 27

5.2系统测试用例 27

5.2系统测试结果 28

6  结论 29

参考文献

致谢

1 引言

1.1研究背景

无人机,是指不搭载人的飞行器。无人机行业高速发展并广泛应用于各行业,随之带来了很多社会问题并对公共安全造成了潜在威胁。目前各国对无人机政策的制定与管控手段,主要从无人机飞行适用性规则技术先决条件、操作限制、飞行审批程序、飞行人员资格认证及道德约束等方面考虑。总的来说,各国对无人机的管控规定大多都是根据无人机的重量、飞行高度、飞行范围、飞行人员资格或其使用目的来限制无人机飞行。从飞行审批程序上来看,一些国家没有制定飞行申请程序许可的最低标准,既不用注册登记平台也不需要飞行审批。相比之下,一些国家则采用单次飞行计划授权方式,每次飞行操作都需要新的申请。其次,各国对于无人机广泛使用造成的公民隐私和数据泄漏问题没有引起足够的重视,几乎没有反映在当前无人机规定中”。目前国内对于无人机的管制措施、管制条例、标准制定还比较滞后,现阶段国内对无人机的监管思路大致以预防为主,追责为辅。从预防措施来看,提高了无人机驾驶员的准入门槛、对敏感空域建立电子围栏、搭建大型无人机管控云平台,以实现对接入无人机运行状态的实时监控。从追责措施来看,建立了无人机实名登记制度。民航局在2017年5月16日下发的《民用无人驾驶航空器实名登记管理规定》要求最大起飞重量在250g(含250g)以上的民用无人机拥有者必须到官方系统进行实名登记“,但随着该系统的上线,经用户反馈存在着一些漏洞。该系统没有对注册登记的用户身份进行真实性验证,严重降低了系统的实用价值且系统要求无人机制造商填报无人机购买者姓名及电话之类的信息,在实际执行中厂家往往出于对消费者信息的保密而难以满足系统相关要求。

本文立足于公安机关对违法违规使用无人机的个人及单位追责查处的实际工作需求,开发了民用无人机实名登记系统,以提高公安机关对有关无人机违规飞行事件追查效率,保证了数据的真实性、安全性及保密性。

1.2 研究方法

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

1.3ThinkPHP框架

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

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

ThinkPHP可以支持windows/Unix/Linux等服务器环境,正式版需要PHP5.0以上版本支持,支持MySqlPgSQLSqlite多种数据库以及PDO扩展,ThinkPHP框架本身没有什么特别模块要求,具体的应用系统运行环境要求视开发所涉及的模块。

作为一个整体开发解决方案,ThinkPHP能够解决应用开发中的大多数需要,因为其自身包含了底层架构、兼容处理、基类库、数据库访问层、模板引擎、缓存机制、插件机制、角色认证、表单处理等常用的组件,并且对于跨版本、跨平台和跨数据库移植都比较方便。并且每个组件都是精心设计和完善的,应用开发过程仅仅需要关注您的业务逻辑。

1.4Tomcat描述

Tomcat是一个不收费的服务器。使用场景比较适合访问量比较少的情况下。意思就是,将Tomcat安装到电脑上的时候,前端HTML页面的访问请求可以通过它进行解析。实际上,Tomcat是对Apache的扩展,但它相对于Apache却是相对独立作业的,由此可以看作它与Apache 是相对独立进程运行的。

Tomcat最开始是sun公司的戴维森进行开发应用的,经过他的努力,不断地将其变为开源的服务器。还由sun公司将其交给了Apache软件基金会。不断发展的tomcat服务器在最近的一个版本中进行了大量的重构和梳理,使其使用起来更加的方便。基于Tomcat负载均衡算法是一种开源的软件,实现方式。不需要增加额外的硬件投入,实现起来也很方便,特别适用于一般的小企业网站服务器在现在和将来一段时间的扩展。从目前的实践来看,可作为需要进行类似应用的一个参考借鉴。

1.5 论文结构安排

通过前期的资料查找以及对其他论文的内容借鉴,本民用无人机实名登记系统论文主要分为以下几个章节:

第1章 交代项目的背景、目的。

第2章 对系统的需求展开分析。

第3章 阐述了民用无人机实名登记系统的总体设计。

第4章 阐明了民用无人机实名登记系统详细功能的实现,主要根据技术性的功能模块功能实现。

第5章 罗列了部分系统调试与测试的记录。

第6章 介绍了民用无人机实名登记系统的结论。

2 民用无人机实名登记系统的需求分析

2.1 系统可行性分析

2.1.1技术可行性分析

民用无人机实名登记系统在数据的存储上使用的MYSQL数据库,在民用无人机实名登记系统开发中使用了了PHP、phpstorm、Tomcat、ThinkPHP这些开发工具的使用,能够给我们的编写工作带来许多的便利。系统使用B/S模式进行开发,使系统的可扩展性和维护性更佳,减少系统配置代码,简化编程代码,目前B/S模式是目前最受欢迎的一种模式。

2.1.2经济可行性分析

在开发民用无人机实名登记系统中所使用的开发软件像phpstorm开发工具、tomcat服务器、ThinkPHP开发框架、MySQL5.7数据库、Photoshop图片处理软件等,这些环境从网上就能免费下载,而且网上都有安装的教程,根据教程一步一步的操作,就可以安装成功,不需要花任何费用,并且民用无人机实名登记系统是自己设计并编码实现的,数据库是使用流行mysql进行数据的存储,开源的mysql等技术的使用,减少系统开发费用。

2.1.3操作可行性分析

此次项目设计的时候我参考了很多类似系统的成功案例,对它们的操作界面以及功能都进行了系统的分析,将众多案例结合在一起,突出以人为本简化操作,所以具有基本计算机知识的人都会操作本项目。因此操作可行性也没有问题。

2.2 系统需求分析

2.2.1功能需求分析

按照民用无人机实名登记系统的角色,我划分为了无人机持有人管理模块、制造商管理模块、政府管理模块和管理员管理模块这四大部分。

无人机持有人:

(1)首页信息:当用户进入本民用无人机实名登记系统的前台的时候,首先展示在眼前的是导航栏、公告、新闻资讯、限飞区、市售无人机、无人机登记、飞行计划、政策法规、我的(我的账户、我的收藏、个人中心)等信息,用户可以根据自己个人的需求进行查看;

(2)注册登录:在系统的左侧有登录+注册按钮,如果用户想要登录到系统当中,可以点击“登录”按钮,然后填写号用户名+密码,点击“登录”按钮,系统会对你的用户名密码进行核对,正确的话就会登录成功了,如果没有账号的话,可以点击左侧的“注册”按钮,然后根据提示输入好用户信息,就可以得到账号和密码了;

(3)公告:用户可以查看后台管理员发布的公告信息,在查询到自己想要了解的公告信息的时候,可以进入查看详细的介绍。

(4)新闻资讯:用户可以查看新闻资讯信息,在查询到自己想要了解的新闻资讯的时候,可以进入查看详细的介绍进行评论、点赞、收藏操作。

(5)飞行计划:用户可以查看飞行计划信息,在查询到自己想要了解的飞行计划的时候,可以进入查看详细的介绍。

(6)限飞区:用户可以查看限飞区信息,在查询到自己想要了解的限飞区的时候,可以进入查看详细的介绍。

(7)市售无人机:用户可以查看市售无人机信息,在查询到自己想要了解的市售无人机的时候,可以进入查看详细的介绍。

(8)我的账户:在前台点击“我的”下面的“我的账户”可以对个人资料+密码修改+自己收藏的信息进行管控。

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

管理员:

(1)登录:管理员在后台可以通过账号和密码进行登录,管理员的账号和密码是在数据库中直接设定的,如果忘记密码可以点击“忘记密码”进行密码找回;

(2)公共管理:管理员可以对系统前台展示的轮播图以及公告进行增删改查,方便用户进行查看。

(3)用户管理:管理员可以对民用无人机实名登记系统中的管理员、制造商、政府以及前台注册的无人机持有人进行审核管理。

(4)信息管理:管理员可以对民用无人机实名登记系统前台展示的新闻资讯以及资讯所属的分类进行管控。

(5)限飞区:管理员点击“限飞区”会显示出所有的限飞区信息,支持输入图片或者限飞区名称对限飞区信息进行查询,如果想要添加新的限飞区信息,点击“添加”按钮,输入图片,限飞区名称、区域范围、限飞时间等信息,点击“提交”按钮就可以添加了,同时可以选择某一条限飞区信息,点击“删除”进行删除,也可以对用户提交的限飞区评论的信息进行管控;

(6)无人机登记:管理员点击“无人机登记”会显示出所有的无人机登记信息,支持输入登记号或者用户姓名或者身份证号对无人机登记信息进行查询,如果想要添加新的无人机登记信息,点击“添加”按钮,输入相关信息,点击“提交”按钮就可以添加了,同时可以选择某一条无人机登记信息,点击“删除”进行删除,也可以点击后面的“用户处罚”按钮对无人机登记的用户处罚信息进行更新维护;

2.2.2非功能性需求分析

民用无人机实名登记系统的非功能性需求比如民用无人机实名登记系统的安全性怎么样,可靠性怎么样,性能怎么样,可拓展性怎么样等。具体可以表示在如下2.1表格中:

2.1 民用无人机实名登记系统非功能需求表

安全性

主要指民用无人机实名登记系统数据库的安装,数据库的使用和密码的设定必须合乎规范。

可靠性

可靠性是指民用无人机实名登记系统能够安装用户的指示进行操作,经过测试,可靠性90%以上。

性能

性能是影响民用无人机实名登记系统占据市场的必要条件,所以性能最好要佳才好。

可扩展性

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

易用性

用户只要跟着民用无人机实名登记系统的页面展示内容进行操作,就可以了。

可维护性

民用无人机实名登记系统开发的可维护性是非常重要的,经过测试,可维护性没有问题

2.3 系统用例分析

民用无人机实名登记系统中无人机持有人角色用例图如图2.1所示:

图2.1 无人机持有人角色用例图

民用无人机实名登记系统中管理员角色用例图如图2.2所示:

图2.2管理员角色用例图

3 民用无人机实名登记系统总体设计

在上一章节中分析了民用无人机实名登记系统的功能性需求、系统性能需求,并且根据需求分析了民用无人机实名登记系统中的用例。那么接下来就要开始对民用无人机实名登记系统架构、主要功能和数据库开始进行设计。

3.1系统功能模块设计

民用无人机实名登记系统整体的功能模块包括管理员+无人机持有人+制造商+政府四个模块,实现了对民用无人机实名登记系统相关信息的查询管理,系统功能模块如图所示。

图3.1 民用无人机实名登记系统功能模块图

3.2数据库设计

3.2.1数据库概念结构设计

下面是整个民用无人机实名登记系统中主要的数据库表总E-R实体关系图。

图3.6 民用无人机实名登记系统总E-R关系图

下面根据民用无人机实名登记系统的数据库总E-R关系图可以得出民用无人机实名登记系统需要很多E-R图,在此罗列出来一些主要的数据库E-R模型图。

图3.7无人机持有人E-R关系图

图3.8 限飞区E-R关系图

图3.9 评论E-R关系图

3.2.2数据库逻辑结构设计

表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:

表commercial_drones (市售无人机)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

commercial_drones_id

int

10

0

N

Y

市售无人机ID

2

product_map

varchar

255

0

Y

N

商品图

3

product_registration_number

varchar

64

0

Y

N

商品注册号

4

product_name

varchar

64

0

Y

N

商品名称

5

product_model

varchar

64

0

Y

N

商品型号

6

market_value

int

10

0

Y

N

0

市场价

7

manufacturer_user

int

10

0

Y

N

0

制造商用户

8

manufacturers_name

varchar

64

0

Y

N

制造商名称

9

manufacturing_brand

varchar

64

0

Y

N

制造品牌

10

company_type

varchar

64

0

Y

N

公司类型

11

product_introduction

longtext

2147483647

0

Y

N

商品介绍

12

hits

int

10

0

N

N

0

点击数

13

praise_len

int

10

0

N

N

0

点赞数

14

recommend

int

10

0

N

N

0

智能推荐

15

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

16

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表drone_holder (无人机持有人)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

drone_holder_id

int

10

0

N

Y

无人机持有人ID

2

drone_users

varchar

64

0

N

N

无人机用户

3

user_name

varchar

64

0

Y

N

用户姓名

4

age

varchar

64

0

Y

N

年龄

5

registered_identity

varchar

64

0

Y

N

注册身份

6

number_of_registrations

varchar

64

0

Y

N

注册数

7

no

varchar

64

0

Y

N

身份证

8

examine_state

varchar

16

0

N

N

未审核

审核状态

9

recommend

int

10

0

N

N

0

智能推荐

10

user_id

int

10

0

N

N

0

用户ID

11

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

12

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表drone_registration (无人机登记)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

drone_registration_id

int

10

0

N

Y

无人机登记ID

2

registration_number

varchar

64

0

Y

N

登记号

3

product_map

varchar

255

0

Y

N

商品图

4

drone_users

int

10

0

Y

N

0

无人机持有人

5

user_name

varchar

64

0

Y

N

用户姓名

6

age

varchar

64

0

Y

N

年龄

7

id_number

varchar

64

0

Y

N

身份证号

8

product_registration_number

varchar

64

0

Y

N

商品注册号

9

product_name

varchar

64

0

Y

N

商品名称

10

product_model

varchar

64

0

Y

N

商品型号

11

manufacturers_name

varchar

64

0

Y

N

制造商名称

12

manufacturing_brand

varchar

64

0

Y

N

制造品牌

13

examine_state

varchar

16

0

N

N

未审核

审核状态

14

examine_reply

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

更新时间

表flight_plan (飞行计划)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

flight_plan_id

int

10

0

N

Y

飞行计划ID

2

flight_registration_number

varchar

64

0

Y

N

飞行登记号

3

drone_users

int

10

0

Y

N

0

无人机持有人

4

user_name

varchar

64

0

Y

N

用户姓名

5

id_number

varchar

64

0

Y

N

身份证号

6

product_name

varchar

64

0

Y

N

商品名称

7

flight_area

varchar

64

0

Y

N

飞行区域

8

flight_date

date

10

0

Y

N

飞行日期

9

flight_time

varchar

64

0

Y

N

飞行时间

10

remarks

text

65535

0

Y

N

备注

11

examine_state

varchar

16

0

N

N

未审核

审核状态

12

examine_reply

varchar

16

0

Y

N

审核回复

13

recommend

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

更新时间

表government (政府)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

government_id

int

10

0

N

Y

政府ID

2

government_accounts

varchar

64

0

N

N

政府账户

3

government_sector

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

更新时间

表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:

表manufacturer (制造商)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

manufacturer_id

int

10

0

N

Y

制造商ID

2

manufacturer_user

varchar

64

0

N

N

制造商用户

3

manufacturers_name

varchar

64

0

Y

N

制造商名称

4

manufacturing_brand

varchar

64

0

Y

N

制造品牌

5

company_type

varchar

64

0

Y

N

公司类型

6

number_of_registrations

varchar

64

0

Y

N

注册数

7

business_license

varchar

255

0

Y

N

营业执照

8

examine_state

varchar

16

0

N

N

未审核

审核状态

9

recommend

int

10

0

N

N

0

智能推荐

10

user_id

int

10

0

N

N

0

用户ID

11

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

12

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表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

更新时间:

表penalty_for_manufacturers (厂商处罚)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

penalty_for_manufacturers_id

int

10

0

N

Y

厂商处罚ID

2

manufacturer_user

int

10

0

Y

N

0

制造商用户

3

manufacturers_name

varchar

64

0

Y

N

制造商名称

4

punishment_name

varchar

64

0

Y

N

处罚名称

5

reason_for_punishment

varchar

64

0

Y

N

处罚事由

6

violation_time

date

10

0

Y

N

违规时间

7

penalty_details

text

65535

0

Y

N

处罚详情

8

recommend

int

10

0

N

N

0

智能推荐

9

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

10

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表policies_and_regulations (政策法规)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

policies_and_regulations_id

int

10

0

N

Y

政策法规ID

2

government_accounts

int

10

0

Y

N

0

政府账户

3

government_sector

varchar

64

0

Y

N

政府部门

4

policy_and_regulation_name

varchar

64

0

Y

N

政策法规

5

effective_date

date

10

0

Y

N

生效日期

6

regulatory_details

longtext

2147483647

0

Y

N

法规详情

7

hits

int

10

0

N

N

0

点击数

8

praise_len

int

10

0

N

N

0

点赞数

9

recommend

int

10

0

N

N

0

智能推荐

10

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

11

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

表restricted_flight_zone (限飞区)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

restricted_flight_zone_id

int

10

0

N

Y

限飞区ID

2

picture

varchar

255

0

Y

N

图片

3

restricted_flight_zone

varchar

64

0

Y

N

限飞区

4

regional_scope

varchar

64

0

Y

N

区域范围

5

restricted_minimum_altitude

varchar

64

0

Y

N

最低高度

6

flight_limit_time

varchar

64

0

Y

N

限飞时间

7

flight_restriction_details

longtext

2147483647

0

Y

N

限飞详情

8

hits

int

10

0

N

N

0

点击数

9

praise_len

int

10

0

N

N

0

点赞数

10

recommend

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

更新时间

表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

更新时间:

4 关键模块的设计与实

民用无人机实名登记系统的详细设计与实现主要是根据前面的民用无人机实名登记系统的需求分析和民用无人机实名登记系统的总体设计来设计页面并实现业务逻辑。主要从民用无人机实名登记系统界面实现、业务逻辑实现这两部分进行介绍。

4.1用户功能模块

4.1.1前台首页界面

当进入民用无人机实名登记系统的时候,首先映入眼帘的是系统的导航栏、轮播图以及公告栏、新闻资讯,同时可以输入关键词对民用无人机实名登记系统的内容进行检索,左侧是用户登录以及注册按钮,其主界面展示如下图4.1所示。

图4.1 首页界面图

4.1.2注册界面

不是民用无人机实名登记系统中用户的是可以在线进行注册的,当用户点击左侧“注册”按钮的时候,当填写上自己的账号+密码+确认密码+昵称+邮箱+手机号等信息后再点击“注册”按钮后将会先验证输入的有没有空数据,再次验证密码和确认密码是否是一样的,最后验证输入的账户名和数据库表中已经注册的账户名是否重复,只有都验证没问题后即可注册成功。其用户注册界面展示如下图4.2所示。

4.2 注册界面图

注册逻辑关键代码如下所示。

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');

            $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 {

                $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.3登录界面

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

4.3登录界面图

登录系统主要代码如下。

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.1.4我的账户界面

当用户点击右上角“我的”这个按钮,会出现子菜单,点击“我的账户”可以对个人的资料、登录系统的密码以及自己收藏的信息进行设置管理,我的账户界面如下图4.7所示。

4.4我的账户界面

4.1.5新闻资讯界面

当访客点击民用无人机实名登记系统中导航栏上的“新闻资讯”后将会进入到该“新闻资讯”列表的界面,然后选择想要看的新闻资讯信息,点击进入到详细界面,在详细界面可以收藏+赞+评论等操作,新闻资讯界面如下图4.5所示。

4.5新闻资讯界面

4.1.6限飞区界面

用户可以查看限飞区信息,在查询到自己想要了解的限飞区的时候,可以进入查看详细的介绍。界面如下图4.6所示。

4.6限飞区界面

4.1.7 市售无人机界面

用户可以查看市售无人机信息,在查询到自己想要了解的市售无人机的时候,可以进入查看详细的介绍。界面如下图4.7所示。

图4.7 市售无人机界面图

4.2管理员功能角模块

民用无人机实名登记系统的理员拥有最高的权限,可以对用户信息、系统信息以及民用无人机实名登记系统相关信息进行管控。

4.2.1公共管理界面

公共管理模块是对前台轮播图以及公告的设置,只有管理员权限才能进行更新维护。界面如下图4.8所示。

图4.8公共管理界面图

4.2.2用户管理界面

民用无人机实名登记系统中的管理员在“用户管理”这一菜单是中可以对注册的用户、制造商、政府以及管理员人员进行管控。界面如下图4.10所示。

4.9 用户管理界面

用户管理代码如下。

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

        $page = 1;

        $size = $table_name == "auth" ? 100 : 10;

        $where = [];

        $order = $table_id.'_id desc';

        $field = '*';

//        echo $order;exit;

        $columns = Db::query( "show COLUMNS FROM `".$table_name."`");

        foreach($columns as $key=>$val){

            $field_name = $val['Field'];

            if(isset($request['like'])){

                if ($request['like']==true){

                    //字段模糊查询

                    if(isset($request[$field_name])){

                        $where[] = [$field_name, '=', $request[$field_name]];

                    }

                }else{

                    //字段模糊查询

                    if(isset($request[$field_name])){

                        $where[] = [$field_name, 'like', '%' . $request[$field_name] . '%'];

                    }

                }

            }else{

                //字段模糊查询

                if(isset($request[$field_name])){

                    $where[] = [$field_name, 'like', '%' . $request[$field_name] . '%'];

                }

            }

            //范围查询

            if(isset($request[$field_name.'_min'])){

                $where[] = [$field_name, '>=', $request[$field_name.'_min']];

            }

            if(isset($request[$field_name.'_max'])){

                $where[] = [$field_name, '<=', $request[$field_name.'_max']];

            }

        }

        //分页

        if (isset($request['page'])){

            $page = $request['page'];

        }

        if (isset($request['size'])){

            $size = $request['size'];

        }

        //排序

        if (isset($request['order'])){

            $order = $request['order'];

        }

        //查询字段

        if (isset($request['field'])){

            $field = $request['field'];

        }

        //模糊查询

        $list= $this->where($where)->order($order)->field($field)->page($page, $size)->select()->toArray();

        foreach($list as &$l){

         foreach($l as &$o){

         if(strpos($o,$_SERVER['HTTP_HOST']) === false){

         $o = str_replace('upload','http://'.$_SERVER['HTTP_HOST'].'/upload',$o);

         }

         }

        }

        return $list;

    }

  

4.2.3限飞区管理界面

管理员点击“限飞区”会显示出所有的限飞区信息,支持选择图片或者限飞区名称对限飞区信息进行查询,如果想要添加新的限飞区信息,点击“添加”按钮,输入图片、限飞区名称、区域范围、限飞最低高度、限飞时间等信息,点击“提交”按钮就可以添加了,同时可以选择某一条限飞区信息,点击“删除”进行删除,也可以对用户提交的限飞区评论的信息进行管控。界面如下图4.10所示。

图4.10 限飞区管理界面

4.2.4无人机登记管理界面

管理员点击“无人机登记”会显示出所有的无人机登记信息,支持输入登记号或者用户姓名对无人机登记信息进行查询,如果想要添加新的无人机登记信息,点击“添加”按钮,输入相关信息,点击“提交”按钮就可以添加了,同时可以选择某一条无人机登记信息,点击“删除”进行删除,也可以点击后面的“用户处罚”按钮对无人机登记的用户处罚信息进行更新维护。界面如下图4.11所示。

图4.11 无人机登记管理界面

无人机登记管理逻辑代码如下所示。

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);

    }

4.2.5飞行计划管理界面

管理员点击“飞行计划”会显示出所有的飞行计划信息,支持通过飞行登记号或者用户姓名或者身份证号对飞行计划信息进行查询,如果想要添加新的飞行计划信息,点击“添加”按钮,输入相关信息,点击“提交”按钮就可以添加了,同时可以选择某一条飞行计划信息,点击“删除”进行删除。界面如下图4.12所示。

图4.12 飞行计划管理界面

飞行计划管理逻辑代码如下所示。

public function del()

    {

        $request = Request::param();

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

        $data = $result;

        return json_encode($data);

}

 

5 系统测试与结果分析

5.1系统测试的目的

系统开发到了最后一个阶段那就是系统测试,系统测试对软件的开发其实是非常有必要的。因为没什么系统一经开发出来就可能会尽善尽美,再厉害的系统开发工程师也会在系统开发的时候出现纰漏,系统测试能够较好的改正一些bug,为后期系统的维护性提供很好的支持。通过系统测试,开发人员也可以建立自己对系统的信心,为后期的系统版本的跟新提供支持。

5.2 系统测试用例

系统测试包括:用户登录功能测试、市售无人机展示功能测试、无人机登记添加、政策法规搜索、密码修改、飞行计划功能测试,如表5-1、5-2、5-3、5-4、5-5、5-6所示:

用户登录功能测试:

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

用例名称

用户登录系统

目的

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

前提

未登录的情况下

测试流程

1) 进入登录页面

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

预期结果

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

实际结果

实际结果与预期结果一致

市售无人机查看功能测试:

表5-2 市售无人机查看功能测试表

用例名称

市售无人机查看

目的

测试市售无人机查看功能

前提

测试流程

点击市售无人机

预期结果

可以查看到所有市售无人机信息

实际结果

实际结果与预期结果一致

管理员添加无人机登记界面测试:

表5-3 管理员添加无人机登记界面测试表

用例名称

添加无人机登记测试用例

目的

测试无人机登记添加功能

前提

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

测试流程

1)管理员点击无人机登记,然后点击添加后并填写信息。

2)点击进行提交。

预期结果

提交以后,页面首页会显示新的无人机登记 

实际结果

实际结果与预期结果一致

政策法规搜索功能测试:

表5-4政策法规搜索功能测试表

用例名称

政策法规搜索测试

目的

测试政策法规搜索功能

前提

测试流程

1)在搜索框填入搜索关键字。

2)点击搜索按钮。

预期结果

页面显示包含有搜索关键字的政策法规

实际结果

实际结果与预期结果一致

密码修改搜索功能测试:

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

用例名称

密码修改测试用例

目的

测试管理员密码修改功能

前提

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

测试流程

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

2)点击进行提交。

预期结果

使用新的密码可以登录

实际结果

实际结果与预期结果一致

飞行计划功能测试:

表5-6飞行计划功能测试表

用例名称

飞行计划测试用例

目的

测试用户飞行计划功能

前提

用户正常登录情况下

测试流程

1)搜索查看政策法规信息,点击飞行计划。

2)填写飞行计划信息,点击进行提交。

预期结果

飞行计划成功

实际结果

实际结果与预期结果一致

5.3 系统测试结果

通过编写民用无人机实名登记系统的测试用例,已经检测完毕用户登录模块、市售无人机展示模块、无人机登记添加模块、政策法规搜索模块、密码修改模块、飞行计划模块功能测试,通过这6大模块为民用无人机实名登记系统的后期推广运营提供了强力的技术支撑。

6  结论

在开发本民用无人机实名登记系统之前我胸有成竹,觉得很简单,但在实际的开发中我发现了自身的很多问题,许多编程思想和方法都还没有掌握牢靠,比如ThinkPHP、phpstorm等许多PHP Web开发技术,通过开发这个民用无人机实名登记系统我成长了很多,懂得了做什么事情都要脚踏实地,不能眼高手低,在本次民用无人机实名登记系统的开发中我逐渐掌握逐渐熟悉的技术。

本次民用无人机实名登记系统的开发中我还学会了很多,例如良好的编程思想和完善的规划思想。在着手编程之前需要罗列出程序框架的大概,脑海中构建出程序的主题框架。做好这一步我们才能胸有成竹的经行开发项目。当设计框架了熟于心之后,需要思考本次编程所需的主要知识点和技术点,并充分学习。如此一来项目的开发才能循序渐进、如丝般顺滑,长久以往就能养成良好的开发习惯。一个程序好不好还要看出的bug多不多,如果在项目完成前做好bug的查验与预防可能发生的事故才能保证程序的稳定长久性运行。如果项目在完工后出现各种问题自己,那么在进入社会后,不仅会给公司团队带来麻烦和增加不必要的工作,还会导致客户流失,公司对自己的评价下降。

在本次项目中我也暴露了诸多问题。对于PHP的编程知识有所欠缺,环境配置和算法上出现诸多问题,时常导致项目运行出错,或者目标的实现有问题。或者实现想法时算法未优化,使得代码冗长,程序运行不顺畅。

参考文献

[1]房歌菲,曹洁,张志鹏.旅游养老视角下在线旅游平台优化路径研究[J].科技与创新,2021(15):108-109+111.

[2]王娜,董焕晴.用户参与的在线旅游网站信息本体构建研究——以马蜂窝在线旅游网站为例[J].现代情报,2021,41(06):64-75.

[3]韦金运,龙健.数字化环境下旅游类网站的交互性设计分析[J].艺术大观,2021(15):49-50.

[4]刘艳玲,姚建盛.智慧旅游专业网站设计课程评价方案探索[J].电脑与电信,2021(05):8-10.

[5]李睿. 基于用户感知的在线旅游网站信息服务质量评价研究[D].吉林大学,2021.

[6]孙岩,李晶.基于SpringBoot的旅游资源管理网站的设计与实现[J].信息技术与信息化,2021(01):37-39.

[7]王家明,李湘.基于大数据分析的新疆智慧旅游网站的设计与实现[J].电脑知识与技术,2021,17(03):129-130+133.

[8]胡涛,兰全祥.基于Spring Cloud的西安旅游网站的设计与实现[J].信息技术与信息化,2020(09):65-67.

[9]吴凡. 在线旅游网站互动体验对消费者价值共创意愿的影响研究[D].南京财经大学,2020.

[10]黄涓,鲍正德,李晨曦.旅游网站的建构与设计——以国内六大旅游网站为例[J].信息与电脑(理论版),2019,31(22):52-54.

[11]张海燕,鹿梦思.基于HOE-ELM模型的旅游网站信息对游客行为意向的影响研究[J].商学研究,2019,26(05):27-40.

[12]王永芳,张秀英.旅游电商网站评价体系构建及实例分析[J].商业经济,2019(06):133-136.

[13]吴贤贤.全域旅游背景下海南省县级旅游目的地网站主题模式探究[J].南方农机,2019,50(11):12-13.

[14]林佳青. 基于技术接受模型的用户对交易型旅游网站的持续使用意愿研究[D].华侨大学,2019.

[15] Smartsave Has Become One Of The Most Recommended Travel Sites For Big Discounts On Attractions[J]. M2 Presswire,2019:

[16]栗璞. 基于云计算平台智能旅游导览系统的研究与实现[D].北京工业大学,2019..

致谢

到此,整个旅游网站就算完成了,虽然过程十分艰难,但是等到都完成的时候,我感觉无比的自豪,虽然设计的系统还存在许多的纰漏,但是我已经拼劲全力,给自己的大学四年画上了一个圆满的句号。

在这里我首先要感谢的就是大学四年来所有教导我的老师,是他们教会了我许多的专业知识以及做人的道理,从一进校门对对开发系统一窍不通到现在能自主开发一个管理系统,里面包含了前台框架、后台框架、业务流程、数据结构、操作系统等各种知识,只有把他们统一运用好,才能够完成整个系统,这都是老师的功劳;其次我要感谢我的指导老师,在开发这个系统的时候,我遇到了无数的问题,经常通过线上、线下的方式去请教导师,每次去请教导师,他从来没有不耐烦,都是细心的引导,告诉我怎么样实现这个功能,怎么样才能使得系统更加完善,然后通过自己查询相关资料解决问题,提高了自己自主解决问题的能力,授人以鱼不如授人以渔,指导老师的这种工作态度受益终生,我也会向老师不断靠拢,向他学习,在此我只想说一句:“老师,谢谢您,您辛苦了”!最后我还要感谢我的室友、同学,在一起学习这四年,他们不但学习上给了我很多建议,在生活上更加给了我帮助,正是有他们的帮助,我的大学生涯才如此完美。

最后,希望自己在未来的道路上能够越走越远,不辜负在大学的学习以及老师们的细致的教导,追风赶月莫停留,平荒尽处是春山。

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值