基于web的停车场管理系统计算机毕业设计源码75913

编程入门 行业动态 更新时间:2024-10-07 18:23:26

基于web的停车场<a href=https://www.elefans.com/category/jswz/34/1769858.html style=管理系统计算机毕业设计源码75913"/>

基于web的停车场管理系统计算机毕业设计源码75913

摘  要

随着汽车工业的迅猛发展,我国汽车拥有量急剧增加。停车场作为交通设施的组成部分,随着交通运输的繁忙和不断发展,人们对其管理的要求也不断提高,都希望管理能够达到方便、快捷以及安全的效果。停车场的规模各不相同,对其进行管理的模式也有不同之处,管理者需要根据自身的条件,选择应用经济、稳定的管理程序,以免选择了高成本的管理系统。

由于科技的发展,社会文明的进步,人们已不在满足于现在的经营、生活方式,比较容易的地为客户和企业用户提供这些功能。我这次课题——停车场管理系统,正是把握住时代的脉搏。

SSM停车场管理系统的主要使用者分为管理员和员工用户,实现功能包括:主页、用户管理、权限管理、个人资料、用户信息、IC卡类型、车位信息、临时停车信息、固定停车信息等功能模块;员工用户:主页、个人资料、用户信息、IC卡类型、车位信息、临时停车信息、固定停车信息等功能模块;由于本网站的功能模块设计比较全面,所以使得整个停车场管理系统的过程得以实现。

本系统的使用可以实现本SSM停车场管理系统的信息化,可以方便管理员进行更加方便快捷的管理,可以提高停车场管理系统的管理效率。

关键词 :停车场管理系统;Mysql数据库;Java语言;SSM框架; 

Abstract

With the rapid development of the automotive industry, China's automobile ownership has sharply increased. As a component of transportation facilities, with the busy and continuous development of transportation, people's requirements for the management of parking lots are constantly increasing, hoping that management can achieve convenient, fast, and safe results. The scale of parking lots varies, and there are also differences in the management modes. Managers need to choose to apply economic and stable management programs based on their own conditions to avoid choosing high cost management systems.

Due to the development of technology and the progress of social civilization, people are no longer satisfied with their current business and lifestyle. They can easily provide these functions to customers and enterprise users. My project on parking lot management system is precisely to grasp the pulse of the times.

The main users of the SSM parking lot management system are divided into administrator and employee users, with functions including: homepage, user management, permission management, personal information, user information, IC card type, parking space information, temporary parking information, fixed parking information, and other functional modules; Employee users: functional modules such as homepage, personal information, user information, IC card type, parking space information, temporary parking information, fixed parking information, etc; Due to the comprehensive design of the functional modules on this website, the entire process of the parking lot management system can be achieved.

The use of this system can achieve the informatization of the SSM parking lot management system, facilitate administrators to manage more conveniently and quickly, and improve the management efficiency of the parking lot management system.

Keywords: Parking lot management system; MySQL database; Java language; SSM framework;

目录

摘  要

Abstract

1 概述

1.1研究背景

1.2 研究意义

1.3 本课题主要工作

2 系统开发环境

2.1 开发技术说明

2.2 SSM框架

2.3 JAVA简介

2.4 Vue.js 主要功能:

2.5 Tomcat服务器

2.6 MySQL数据库

3 系统分析

3.1 可行性分析

3.1.1 技术可行性

3.1.2操作可行性

3.1.3 经济可行性

3.1.4 法律可行性

3.2系统流程分析

3.2.1系统开发流程

3.2.2 用户登录流程

3.2.3 系统操作流程

3.2.4 添加信息流程

3.2.5 修改信息流程

3.2.6 删除信息流程

3.3用例分析

3.4系统流程分析

3.4.1添加信息流程

3.4.2操作流程

3.4.3删除信息流程

4系统概述

4.1 系统结构设计

4.2数据库设计

4.2.1 数据库设计原则

4.2.2 数据库实体

4.3 数据库设计原则

4.3.1 数据库表设计

表employee_user (员工用户)

表fixed_parking_information (固定停车信息)

表hits (用户点击)

表ic_card_type (IC卡类型)

表parking_space_information (车位信息)

表temporary_parking_information (临时停车信息)

表upload (文件上传)

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

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

表user_information (用户信息)

5系统界面实现

5.1 登录

5.2 管理员功能模块

5.3员工用户端功能模块

6系统测试

6.1系统测试的意义

6.2 测试方法

6.3测试分析

结    论

致    谢

参考文献

1 概述

1.1研究背景

伴随计算机产业快速发展,电子计算机已广泛应用于信息管理、文字处理、辅助设计、辅助教学及大家日常生活中。尤其是在计算机操作系统含有了图形化界面后,使用计算机已经不再是一些专业人员专利,各行各业大家不需要经过专业化训练就能自如在计算机上进行多种复杂操作。时下,为了能发明更大经济效益和方便管理,越来越多管理设施迫切需要引入现代化管理手段,而计算机大容量操作,正确计算,使它成为设施管理不可缺乏手段之一,但伴随计算机应用不停深入,设施对软件需求也不停增加,越来越多设施期望拥有适合自己需要特殊软件来满足自己特殊要求。

对于当今停车场题来说,其车辆进出量大,多种信息管理内容复杂,查询和管理出入车辆信息和车辆设计信息等工作由人工完成将是很累,可能还很不切实际,不仅浪费了很多人力物力资源,而且还很轻易出现差错,有一个符合要求软件对其进行智能化毕业设计选题是最好不过,节省了人力物力资源,而且对多种信息把握和操作也愈加方便了,对全部信息有了一个全局掌握。对于一名专业信息技术人员来说,怎样最大程度地利用车辆管理部门多年来在数据库系统上投资,是每一个从事信息技术工作专业人员全部应该考虑问题。现在全国很多大型停车场车辆出入登记全部采取了计算机管理,这么就需要一个管理软件来为车辆者服务,帮助她们来完成管理数量巨大车辆出入登记等这么一个庞大工作。

1.2 研究意义

国外计算机网络的技术领先于中国,几乎所有的停车场都采用了电子化的管理方法,这种方法不但节约了人力资源,最主要的一点是,便于信息的统一管理。基于对上述的认识,传统的管理方式确实存在很多弊端,如对象范围广,数据存储不易;填写的数据多,不易存档,成千上万的信息和堆积如山的单据对管理人员来说是一个负担,需要大量的文档资料,管理效率也不高。所以该系统针对停车场管理系统的特点以及管理中实际需要而设计,能够有效地实现停车场管理系统的信息化,减轻管理人员的工作负担,高效率、规范化地管理大量的停车出入信息,并避免人为操作的错误和不规范行为。

现在也有很多的停车场管理系统和分析系统,但是有的过于简单,有的过于复杂,不能完全用于停车场的应用,而每个停车场都有自身的特点和具体情况,所以不一定适用。针对于这种情况,我认为很有必要开发一套针对于停车场管理系统。这样一个系统不但可以降低工作量,提高办公效率,而且可以使分散的车位信息得到集中管理,这对减轻管理工作负担,提高管理水平,实现停车场管理系统的现代化具有重要意义。

1.3 本课题主要工作

一开始,本文就对系统内谈到的基本知识,从整体上进行了描述,并在此基础上进行了系统分析。为了能够使本系统较好、较为完善的被设计实现出来,就必须先进行分析调查。基于之前相关的基础,在功能上,对新系统进行了细致的分析。然后通过详细的分析,进行系统设计,其次,系统在实施的可行性上,我选择了SSM技术来进行开发设计,在数据存储上,采用 Mysql数据库来进行设计。由于SSM框架和Mysql都已经非常成熟,因此无论在各个方面,都非常可靠安全实用。最后对系统进行测试完善并发布。

2 系统开发环境 

2.1 开发技术说明

本系统前端部分基于MVVM模式进行开发,采用B/S模式,后端部分基于Java的ssm框架进行开发。

前端部分:前端框架采用了比较流行的渐进式JavaScript框架Vue.js。使用Vue-Router和Vuex实现动态路由和全局状态管理,Ajax实现前后端通信,Element UI组件库和Lay UI组件库使页面快速成型,项目前端通过栅格布局实现响应式,可适应PC端、平板端、手机端等不同屏幕大小尺寸的完美布局展示。

后端部分:采用ssm作为开发框架,同时集成MyBatis、Redis等相关技术。 

2.2 SSM框架

当今流行的“SSM组合框架”是Spring + SpringMVC + MyBatis的缩写,受到很多的追捧,“组合SSM框架”是强强联手、各司其职、协调互补的团队精神。web项目的框架,通常更简单的数据源。Spring属于一个轻量级的反转控制框架(IoC),但它也是一个面向表面的容器(AOP)。SpringMVC常常用于控制器的分类工作模式,与模型对象分开,程序对象的作用与自动取款机进行处理。这种解耦治疗使整个系统的个性化变得更加容易。MyBatis是一个良好的可持续性框架,支持普通SQL查询,同时允许对存储过程的高级映射进行数据的优化处理。大型Java Web应用程序的由于开发成本太高,开发后难以维护和开发过程中一些难以解决的问题,而采用“SSM组合框架”,它允许建立业务层次结构,并为这个问题提供良好的解决方案。

所以结合驾考管理系统的需求及功能模块的实现,使用SSM技术是最合适的,而且SSM的拓展性比较好,对于系统在后期使用过程中可以不断对系统功能进行拓展,是系统更完成,更方便的满足用户管理。

2.3 JAVA简介

Java主要采用CORBA技术和安全模型,可以在互联网应用的数据保护。它还提供了对EJB(Enterprise JavaBeans)的全面支持,java servlet API,SSM(java server pages),和XML技术。JAVA语言是一种面向对象的语言,它通过提供最基本的方法来完成指定的任务,开发者只需要知道一些概念就能够编写出一些应用程序。Java程序相对较小,其代码能够在小机器上运行。Java是一种计算机编程语言,具有封装、继承和多态性三个主要特性,广泛应用于企业Web应用程序开发和移动应用程序开发。

Java语言和一般编译器以及直译的区别在于,Java首先将源代码转换为字节码,然后将其转换为JVM的可执行文件,JVM可以在各种不同的JVM上运行。因此,实现了它的跨平台特性。虽然这使得Java在早期非常缓慢,但是随着Java的开发,它已经得到了改进。

2.4 Vue.js 主要功能:

Vue.js是一套构建用户界面的渐进式框架。与其他重量级框架不同的是,Vue采用自底向上增量开发的设计。Vue 的核心库只关注视图层,并且非常容易学习,非常容易与其它库或已有项目整合。另一方面,Vue 完全有能力驱动采用单文件组件和Vue生态系统支持的库开发的复杂单页应用。

Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。

Vue.js 自身不是一个全能框架——它只聚焦于视图层。因此它非常容易学习,非常容易与其它库或已有项目整合。另一方面,在与相关工具和支持库一起使用时,Vue.js 也能驱动复杂的单页应用。

2.5 Tomcat服务器

Tomcat属于一种轻型的服务器,所以说在中小企业中并不具有普适性。但是当程序员需要开发或调试SSM 程序时,则通常会将该服务器作为首选。对于一个仅具有计算机基础知识的人来说,计算机系统具有一个好的Apache服务器,可以很好的对HTML 页面进行访问。Tomcat 虽然是Apache的扩展,但是它们都是可以独立运行的,二者是不互相干扰的。当配置正确的时候,Apache服务器为HTML 页面的运行提供技术支持,Tomcat 的任务则是运行Servle和SSM 页面。Tomca也具有一定的HTML页面处理功能。

2.6 MySQL数据库

数据库是系统开发过程中不可或缺的一部分。在WEB应用方面,MySQL AB开发了一个具有很大优势的MySQL关系数据库管理系统。 MySQL可以将数据存储在不同的表中,这非常灵活,并且还可以提高系统在实际应用中的速度。数据库访问最常用于标准SQL语言,MySQL用于SQL语言,因此它具有高度兼容性。数据库的操作是必不可少的,包括对数据库表的增加、删除、修改、查询等功能。现如今,数据库可以分为关系型数据库和非关系型数据库,Mysql属于关系性数据库,Mysql数据库是一款小型的关系型数据库,它以其自身特点:体积小、速度快、成本低等,Mysql数据库是目前最受欢迎的开源数据库。

在WEB应用技术中, Mysql数据库支持不同的操作系统平台,虽然在不同平台下的安装和配置都不相同,但是差别也不是很大,Mysql在Windows平台下两种安装方式,二进制版和免安装版。安装完Mysql数据库之后,需要启动服务进程,相应的客户端就可以连接数据库,客户端可通过命令行或者图形界面工具登录数据库。

3 系统分析

所谓系统分析就是,管理员通过与用户客户端的沟通,所获取的信息,然后把这些信息通过需求说明书的方式展示给用户和开发人员。在软件功能发展的历史长河中,很长时间,特别是最开始的时候,需求分析的重要性并不被人们所认同,例如当时美国IBM公司为英国电信公司开发一套信息管理系统,在需求不明确的情况下开始开发,最初的工期为一年,由于需求获取不清晰导致工期推迟了半年多,造成巨大损失。我们很多软件公司也存在这种情况,边需求,边开发,甚至与客户没有沟通清楚的情况下,直接照搬同类型的项目进行更改,导致到系统验收的时候,重新更改,造成了人力、物力的极大浪费。而导致这一切后果的原因就是需求获取不及时、不清楚、不全面。

3.1 可行性分析

停车场管理系统主要目标是实现车位信息、临时停车信息、固定停车信息、用户信息等相关信息管理服务。在确定了目标后,我们从以下四方面对能否实现本系统目标进行可行性分析。

3.1.1 技术可行性

停车场管理系统主要采用SSM技术,java语言,Mysql数据库,对于应用程序的开发要求具备完整功能,使用简单的特点,并建立一个数据完整安全稳定的数据库。停车场管理系统的开发技术具有很高可行性,且开发人员掌握了一定的开发技术,所以系统的开发具有可行性。

3.1.2操作可行性

停车场管理系统的登录界面简单易于操作,采用常见的界面窗口来登录界面,通过电脑进行访问操作,用户只要平时使用过电脑都能进行访问操作。此系统的开发采用SSM框架、结合java语言,这些开发环境使系统更加完善。本系统具有易操作、易管理、交互性好的特点,在操作上是非常简单的。因此本系统可以进行开发。

3.1.3 经济可行性

停车场管理系统是服务端基于B/S模式、java技术,客户端采用微信、采用Mysql数据库储存数据,所要求的硬件和软件环境,市场上都很容易购买,程序开发主要是管理系统的开发和维护。所以程序在开发人力、财力上要求不高,而且此系统不是很复杂,开发周期短,在经济方面具有较高的可行性。

3.1.4 法律可行性

此停车场管理系统是自己设计的管理系统,具有很大的实际意义。因为无论是软件还是数据库,采用的都是开源代码,因此这个系统的开发和设计,并不存在侵权等问题,在法律上完全具有可行性。

综上所述,停车场管理系统在技术、经济、操作和法律上都具有很高的可行性,开发此程序是可行的。

3.2系统流程分析

3.2.1系统开发流程

停车场管理系统开发时,首先进行需求分析,进而对系统进行总体的设计规划,设计系统功能模块,数据库的选择等,本系统的开发流程如图3-1所示

图3-1系统开发流程图

3.2.2 用户登录流程

为了保证系统的安全性,要使用本系统对系统信息进行管理,必须先登陆到系统中。如图3-3所示。

图3-2 登录流程图

3.2.3 系统操作流程

用户打开客户端并进入系统后,会先显示登录界面,输入正确的用户名和密码,系统自动检测信息,若信息无误,则用户会进入系统功能界面,进行操作,否则会提示错误无法登录,操作流程如图3-3所示。

图3-3 系统操作流程图

3.2.4 添加信息流程

管理员可以对车位信息等进行信息的添加、删除、修改,用户也可以对自己权限内的信息进行添加删除、修改等等操作,输入信息后,系统会自行验证输入的信息和数据,若信息正确,会将其添加到数据库内,若信息有误,则会提示重新输入信息,添加信息流程如图3-4所示。

图3-4 添加信息流程图

3.2.5 修改信息流程

管理员可以对车位信息、用户信息等进行信息的修改,用户也可以对自己权限内的信息进行修改,首先进入修改信息界面,输入修改信息数据,系统进行数据的判断验证,修改信息合法则修改成功,信息更新至数据库,信息不合法则修改失败,重新输入。修改信息流程图如图3-5所示。

图3-5 修改信息流程图

3.2.6 删除信息流程

管理员可以对车位信息、用户信息等进行信息的删除,对要删除的信息进行选中后,点击删除按钮,系统会询问是否确定,若点击确定,则系统会删除掉选中的信息,并在数据库内对信息进行删除,删除信息流程图如图3-6所示。

图3-6 删除信息流程图

3.3用例分析

1员工用户主要负责主页、个人资料、用户信息、IC卡类型、车位信息、临时停车信息、固定停车信息等功能模块,下图所示为员工用户的用例图。

图3-1 员工用户用例图

3.管理员主要负责主页、用户管理、权限管理、个人资料、用户信息、IC卡类型、车位信息、临时停车信息、固定停车信息等功能模块;下图所示描述管理员的用例图。

图3-3 管理员用例图

3.4系统流程分析

3.4.1添加信息流程

添加信息,编号系统使用自动编号模式,没有用户填写,用户添加信息输入信息,系统将自动确认的信息和数据,验证的成功是有效的信息添加到数据库,信息无效,重新输入信息。添加信息流程如图3-3所示。

图3-3 添加信息流程图

3.4.2操作流程

用户想进入系统,首先进入系统登录界面,通过正确的用户名、密码,选择登录类型登录,系统会检查登录信息,信息正确,然后输入相应的功能界面,提示信息错误,登录失败。系统操作流程如图3-4所示。

图3-4操作流程图

3.4.3删除信息流程

用户选择要删除的信息并单击Delete按钮。系统提示是否删除信息。如果用户想要删除信息,系统将删除信息。系统数据库删除信息。删除信息流程图如图3-5所示。

图3-5 删除信息流程图

4系统概述

进过系统的分析后,就开始记性系统的设计,系统设计包含总体设计和详细设计。总体设计只是一个大体的设计,经过了总体设计,我们能够划分出系统的一些东西,例如文件、文档、数据等。而且我们通过总体设计,大致可以划分出了程序的模块,以及功能。但是只是一个初步的分类,并没有真正的实现。

整体设计,只是一个初步设计,而且,对于一个项目,我们可以进行多个整体设计,通过对比,包括性能的对比、成本的对比、效益的对比,来最终确定一个最优的设计方案,选择优秀的整体设计可以降低开发成本,增加公司效益,从这一点来讲,整体设计还是非常重要的。

停车场管理系统工作原理图如图4-1所示:

图4-1 系统工作原理图

4.1 系统结构设计

系统架构图属于系统设计阶段,系统架构图只是这个阶段一个产物,系统的总体架构决定了整个系统的模式,是系统的基础。基于停车场管理系统的整体结构设计如图4-2所示。

图4-2 系统结构图

4.2数据库设计

数据库是计算机信息系统的基础。目前,电脑系统的关键与核心部分就是数据库。数据库开发的优劣对整个系统的质量和速度有着直接影响。

4.2.1 数据库设计原则

概念模式它主要是建立在数据需求分析的基础上,它通常是用概念数据模型来表示各个数据之间的联系,并且对系统用户进行信息的处理和管理,同时建立起E-R图来表示具体的实体、属性和联系的关系。

4.2.2 数据库实体

4.3 数据库设计原则

每个数据库的应用它们都是和区分开的,当运行到一定的程序当中,它就会与自己相关的协议与客户端进行通讯。那么这个系统就会对使这些数据进行连接。当我们选择哪个桥段的时候,接下来就会简单的叙述这个数据库是如何来创建的。当点击完成按钮的时候就会自动在对话框内弹出数据源的名称,在进行点击下一步即可,直接在输入相对应的身份验证和登录密码。 

停车场管理系统的数据流程:

图4-4  系统数据流程图

停车场管理系统实体E-R图,如图4.5所示。

图4.5实体E-R图

4.3.1 数据库表设计

数据库的表信息属于设计的一部分,下面介绍数据库中的各个表的详细信息。

表employee_user (员工用户)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

employee_user_id

int

10

0

N

Y

员工用户ID

2

employee_id

varchar

64

0

Y

N

员工工号

3

employee_name

varchar

64

0

Y

N

员工姓名

4

employee_gender

varchar

64

0

Y

N

员工性别

5

examine_state

varchar

16

0

N

N

已通过

审核状态

6

recommend

int

10

0

N

N

0

智能推荐

7

user_id

int

10

0

N

N

0

用户ID

8

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

9

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表fixed_parking_information (固定停车信息)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

fixed_parking_information_id

int

10

0

N

Y

固定停车信息ID

2

parking_space_number

varchar

64

0

Y

N

车位编号

3

parking_position

varchar

64

0

Y

N

车位位置

4

user_name

varchar

64

0

Y

N

用户姓名

5

vehicle_number_plate

varchar

64

0

Y

N

车辆号牌

6

charging_mode

varchar

64

0

Y

N

收费模式

7

parking_expenses

varchar

64

0

Y

N

停车费用

8

note_details

text

65535

0

Y

N

备注详情

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

更新时间

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

表ic_card_type (IC卡类型)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

ic_card_type_id

int

10

0

N

Y

IC卡类型ID

2

ic_card_type

varchar

64

0

Y

N

IC卡类型

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

更新时间

表parking_space_information (车位信息)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

parking_space_information_id

int

10

0

N

Y

车位信息ID

2

parking_space_number

varchar

64

0

Y

N

车位编号

3

parking_position

varchar

64

0

Y

N

车位位置

4

parking_space_status

varchar

64

0

Y

N

车位状态

5

parking_expenses

int

10

0

Y

N

0

停车费用

6

parking_space_description

text

65535

0

Y

N

车位说明

7

parking_space_cover

varchar

255

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

更新时间

表temporary_parking_information (临时停车信息)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

temporary_parking_information_id

int

10

0

N

Y

临时停车信息ID

2

parking_space_number

varchar

64

0

Y

N

车位编号

3

parking_position

varchar

64

0

Y

N

车位位置

4

vehicle_number_plate

varchar

64

0

Y

N

车辆号牌

5

parking_expenses

int

10

0

Y

N

0

停车费用

6

parking_duration

datetime

19

0

Y

N

停车时间

7

parking_time

int

10

0

Y

N

0

停放时长

8

total_expenses

varchar

64

0

Y

N

总计费用

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

更新时间

表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

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

表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

更新时间:

表user_information (用户信息)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

user_information_id

int

10

0

N

Y

用户信息ID

2

user_name

varchar

64

0

Y

N

用户姓名

3

user_gender

varchar

64

0

Y

N

用户性别

4

contact_information

varchar

64

0

Y

N

联系方式

5

vehicle_information

text

65535

0

Y

N

车辆信息

6

ic_card_number

varchar

64

0

Y

N

IC卡号

7

ic_card_type

varchar

64

0

Y

N

IC卡类型

8

owner_nature

varchar

64

0

Y

N

车主性质

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

更新时间

5系统界面实现

5.1 登录

管理员输入个人的账号、密码、图片验证登录系统,这时候系统的数据库就会在进行查找相关的信息,如果我们输入的账号、密码不正确,数据库就会提示出错误的信息提示,同时会提示管理员重新输入自己的账号、密码,直到账号密码输入成功后,会提示登录成功的信息。管理员登录效果图如图5.1所示:

图5.1登录界面

登录代码如下:

 /**

     * 登录

     * @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;

}

5.2 管理员功能模块

 管理员首页

管理员可以查看后台服务端后台主页、用户管理、权限管理、个人资料、用户信息、IC卡类型、车位信息、临时停车信息、固定停车信息等操作。管理员服务端效果图如图5.2所示。

图5.2管理员服务端界面图

管理员功能页代码如下:

  <mapper namespace="com.project.demo.dao.base.BaseMapper">

    <select id="selectBaseList" resultType="java.util.LinkedHashMap">

        ${select}

    </select>

    <select id="selectBaseCount" resultType="Integer">

        ${count}

    </select>

    <select id="selectBaseOne" resultType="Object">

        ${select}

    </select>

    <update id="updateBaseSql">

        ${sql}

    </update>

    <delete id="deleteBaseSql">

        ${sql}

    </delete>

</mapper>

用户管理

管理员对员工用户进行管理等操作,并可进行详情添加、删除、修改、查看等操作。用户管理效果图如图5.3所示。

图5.3用户管理界面图

用户管理代码如下:

    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;

}

车位信息管理

管理员对车位信息进行管理查看、添加、删除等操作。车位信息效果图如图5.4所示。

图5.4车位信息界面图

车位信息代码如下:

 public String encryption(String plainText) {

        String re_md5 = new String();

        try {

            MessageDigest md = MessageDigest.getInstance("MD5");

            md.update(plainText.getBytes());

            byte b[] = md.digest();

            int i;

            StringBuffer buf = new StringBuffer("");

            for (int offset = 0; offset < b.length; offset++) {

                i = b[offset];

                if (i < 0)

                    i += 256;

                if (i < 16)

                    buf.append("0");

                buf.append(Integer.toHexString(i));

            }

            re_md5 = buf.toString();

        } catch (Exception e) {

            e.printStackTrace();

        }

        return re_md5;

}

IC卡类型管理

管理员对IC卡类型进行管理查看、添加、删除等操作。IC卡类型管理效果图如图5.5所示。

图5.5IC卡类型界面图

IC卡类型管理代码如下:

   @PostMapping("/add")

    @Transactional

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

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

        this.addMap(paramMap);

        return success(1);

}

    @Transactional

    public Map<String, Object> addMap(Map<String,Object> map){

        service.insert(map);

        return success(1);

}

5.3员工用户端功能模块

员工用户登录

员工用户在登陆页面填写账号、密码、图片验证等信息进行登录,如图5.7所示

图5.7员工用户登录界面图

员工用户登录的逻辑代码如下。

/**

     * 登录

     * @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;

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

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

            map.put("username", username);

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

        }

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

            map.put("email", email);

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

        }

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

            map.put("phone", phone);

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

        }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.select(groupMap, new HashMap<>()).getResultList();

        if (groupList.size()<1){

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

        }

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

        //查询用户审核状态

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

            String sql = "select examine_state from "+ userGroup.getSourceTable() +" WHERE user_id = " + byUsername.getUserId();

            String res = String.valueOf(service.runCountSql(sql).getSingleResult());

            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, "账号或密码不正确");

        }

}

 用户首页

用户可以查看后台服务端主页、个人资料、用户信息、IC卡类型、车位信息、临时停车信息、固定停车信息等操作。管理员服务端效果图如图5.8所示。

图5.8用户服务端界面图

   

  个人信息管理

个人信息详情页面可查看头像、用户名、用户组、状态、昵称、手机号码、邮箱等操作,如图5.9所示。

图5.9个人信息界面图

车位信息

车位详情页面可查看车位编号、位置、状态、说明、封面、停车费用等信息,进行查询等操作,如图5.10所示。

图5.10车位信息界面图

用户信息

用户信息详情页面可查看用户姓名、性别、联系方式、车辆信息、IC卡号、IC卡等信息,进行详情、查询等操作,如图5.10所示。

图5.11用户信息界面图

6系统测试

系统开发的最后一个步骤就是系统测试,系统测试也是整个系统十分重要的一个环节,测试的好坏关系到产品的发展。客户对软件的质量、性能和可靠性等需求就要通过测试来实现。测试过程要必须遵循严谨性、完善性、规范性的原则,测试的主要目的就是看看在系统运行中,是否会出现bug,然后对出现的bug进行调试,直到程序完美运行。但是软件的测试只能尽可能的减少bug,理论上来说是无法达到消除bug。但是bug越少,系统出错的几率就越低,用户使用起来也更方便、更安全。

近年来,软件包含测试从现在的检验当中来看,系统接近预期目标可能出现的问题,并对这些错误做出相应的修正,假如我们不进行早期的测试错误就会延续下去,最后所做出的成品就会有很大的困难。

我们要在这个测试的过程当中找出错误。测试成软件开发的主要一部分,自从有了程序的设计那天开始,它就成为了重要的组成部分。经过统计来看,软件测试可以占据这个系统45%的工作量,而在软件开发的成本当中,对于测试成本来说它包含了很多的测试工作。每个程序测试时都会出现和遇到错误。在整个程序的开发过程当中,人为去查找错误是非常复杂和困难的,所以我们一般都会找一些测试的工具来进行测试

6.1系统测试的意义

随着现代信息的快速发展,在社会各大领域中已经都开始应用网络信息技术,在应用网络技术的同时人们也开始把软件的质量问题作为了一个重要焦点来关注,因为一个软件的好与坏它决定着这个系统在市场上的生存,所以我们必须要把软件质量来做好,这样才有一定的生存能力。对于用户来说它们首先选用的都是保证这个系统软件的质量问题,因为一个系统的软件质量决定着用户在后期上成本经济的问题。图6-1就是纠错测试流程。

图6-1 测试与纠错信息流程

6.2 测试方法

具体测试方法包括:黑盒测试和白盒测试。

黑盒测试又被人们称作为功能测试,通常是在程序的接口来做一些测试的方法,它一般包括对程序的功能和使用的方法来做出一些数据的接受和输出,同时还可以做出正确的输出信息,并保证与外部信息的完整性。

白盒测试通常被人们称作为结构测试,在整个程序的结构和处理当中它是由程序当中的逻辑测试和检验程序来完成一些正确的工作。

具体的功能测试它是包括:系统的适用性、准确性、安全性等功能测试。

6.3测试分析

本停车场管理系统满足相关信息的管理需求,在设计时借鉴了国内外优秀网站的优点,从界面到系统设计都保证了管理员以及用户能够方便操作。系统的主要特点和优点归纳如下:

(1)本系统用的移置性和针对性都比较高,因为针对性高可以提供更好的服务而移置性可以在多个系统上运行,更给用户带来了极大的方便。

(2)该停车场管理系统内容全面,管理方便可以及时的全面的处理各种错误,异常,这样避免了很多因用户的马虎操作而出现的失误,其操作方便,用户界面友好,能够上网的人都可以很好的进行操作。

经过对上述的测试结果分析,所有基本功能齐全,操作简单,系统运行性能良好,系统安全可靠,能促进停车场管理系统的发展,发展前景广阔。

结    论

本系统通过对SSM、java和Mysql数据库的简介,从硬件和软件两反面说明了停车场管理系统的可行性,本文结论及研究成果如下:实现了java与Mysql相结合构建的停车场管理系统,网站可以响应式展示。通过本次停车场管理系统的研究与实现,我感到学海无涯,学习是没有终点的,而且实践出真知,只有多动手才能尽快掌握它,经验对系统的开发非常重要,经验不足,就难免会有许多考虑不周之处。比如要有美观的界面,更完善的功能,才能吸引更多的用户。

由于在此之前对于Java知识没有深入了解,所以从一开始就碰到许多困难,例如一开始的页面显示不规范、数据库连接有问题已经无法实现参数的传递等等,不过通过在网上寻找有关资料以及同学的帮助下最后都得到了解决,在此过程中,我不仅学到了很多知识,也提高了自己解决问题的能力,尤其是学会如何从大量的信息中筛选出所需有用的信息,同时我更加深刻的体会到了,虽然书本上的大部分知识都是有价值,正确的,但实际上每个人编程的思路和对数据处理的方法、思想都是不同的,这就要求我们一定要通过实践才能找到解决问题的方案。在此次毕业设计活动中,我不断的提高了自己,也得到了宝贵的经验,我相信这些对我以后的发展都会有很大帮助。

通过这次停车场管理系统的开发,我参考了很多相关系统的例子,取长补短,吸取了其他系统的长处,逐步对该系统进行了完善,但是该系统还是有很多的不足之处,有待以后进一步学习。

实践证明,停车场管理系统有着非常好的发展前景,经过测试运行,系统各项功能都十分完善,界面漂亮,使用方便,操作容易,在技术理论上已经成熟。

致    谢

大学的学习生活在这个季节将结束,但是在我的生命这仅仅只是一个逗号,我将面对另一个的开始。通过这次毕业设计的整个开发过程,从需求分析到具体功能实现,再到最终测试和维护的理解有了很大的进步,让我对系统开发有了更深刻的认识,对我个人的实践能力和解决问题的能力,都有了很大的帮助。这是这次毕业设计最大的收获。

首先要感谢我的指导老师,他在论文写作上,给予了我各种无私的帮助,治学严谨,严格要求,使我获得了很大的收获。老师深厚的理论知识和丰富的实践经验,都深深的影响到我,在这方面,我谨表示衷心的感谢。

其次,我还要对所有的老师和同学表示感谢,他们在我学习的过程中,都积极的提供了很多帮助,无论是专业知识,还是实践操作技能,也能够让我在论文写作中,遇到的一些难题迎刃而解。

最后,对阅读和评审本论文的各位老师表示衷心的感谢!

参考文献 

[1]王淑琳. 一种停车场管理系统及其设备[P]. 广东省:CN115788135A,2023-03-14.

[2]Shimi Amir,Ebrahimi Dishabi Mohammad Reza,Abdollahi Azgomi Mohammad. An intelligent parking management system using RFID technology based on user preferences[J]. Soft Computing,2022,26(24).

[3]程琳,樊江涛,李龙,冷尊淼,李田太郎.智能停车场管理系统设计与实现[J].数字技术与应用,2021,39(05):169-171.DOI:10.19695/jki12-1369.2021.05.55.

[4]杨丽君,韩英杰.智慧停车场管理系统的设计与实现[J].科学技术创新,2021(07):95-96.

[5]程瑶. 基于物联网的停车场管理系统设计与研究[D].安徽理工大学,2020.DOI:10.26918/dki.ghngc.2020.000794.

[6]江小静,解祥新,杭益柳,孙景玉.小区自助停车场管理系统的设计与实现[J].无线互联科技,2020,17(21):35-36.

[7]晏冬. A公司停车场管理系统营销策略改进研究[D].哈尔滨工业大学,2021.DOI:10.27061/dki.ghgdu.2021.002509.

[8]黄大维. 智能停车场管理系统设计研究[C]//中国智慧工程研究会智能学习与创新研究工作委员会.2020万知科学发展论坛论文集(智慧工程二).2020万知科学发展论坛论文集(智慧工程二),2020:1022-1031.DOI:10.26914/ckihy.2020.014187.

[9]王华文, 智能停车场管理系统软件. 安徽省,安徽德顺智能科技有限公司,2020-05-21.

[10]吴宇涵,关蕊,郭佩瑶,赵伟,刘一贤.智能停车场管理系统的设计[J].电子测试,2019(13):35-36+34.DOI:10.16520/jki.1000-8519.2019.13.012.

[11]张健,刘志成.一种智能停车场管理系统的设计[J].山西电子技术,2019(03):39-41+43.

[12]杨亮宇,朱思怡,蔡家轩,蔡晓童,蒋全胜.基于互联网+的智能停车场管理系统[J].科技视界,2019(10):220-221.DOI:10.19694/jki.issn2095-2457.2019.10.096.

[13]. Robert Bosch GmbH; Patent Issued for Parking Lot Management System (USPTO 10,148,507)[J]. Journal of Transportation,2018.

[14]杜昕娉,张娣,刘琦.浅析智能停车场管理系统[J].南方农机,2018,49(23):171.

[15]崔旭冉,刘娅迪.基于Java的智能停车场管理系统的开发与研究[J].现代信息科技,2018,2(11):69-71.

[16]Jeong Chan Do,Ji Man Oh,Wang Heon Lee. A License Plate Recognition using Neural Network and Autonomous Mobile Robot in Intelligent Parking Lot Management System[J]. 제어로봇시스템학회 국제학술대회 논문집,2018.

[17]向露.基于SSM的智能停车场管理系统的设计与实现[J].电子设计工程,2018,26(13):24-27+32.DOI:10.14022/jki.dzsjgc.2018.13.006.

[18]梁立生.小区停车场管理系统的组成及一般应用浅析[J].改革与开放,2009(12):159.DOI:10.16653/jki.32-1034/f.2009.12.012.

[19]于征, 一路免取卡停车场管理系统. 福建省,厦门市路桥信息工程有限公司,2009-04-01.

[20]Saito M,Ph.D.,P.E., et al. NEED FOR PAVEMENT MANAGEMENT SYSTEMS FOR PARKING LOTS AND FREIGHT TRANSFER YARDS[C]//中国公路学会.Proceedings of the 4~(th) International Conference on Road & Airfield Pavement Technology.Proceedings of the 4~(th) International Conference on Road & Airfield Pavement Technology,2002:120-128.

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

更多推荐

基于web的停车场管理系统计算机毕业设计源码75913

本文发布于:2024-02-13 11:15:29,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1758107.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:管理系统   毕业设计   停车场   源码   计算机

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!