目 录
建材生产智能化系统设计
摘要
在当今的建筑行业中,智能化生产系统的需求日益增长。为了满足这一需求,提出了建材生产智能化系统的设计。本系统旨在通过先进的技术手段,提高建材生产的效率、质量和可持续性。
智能化系统的引入将为建材生产带来革命性的变化。传统的生产方式往往面临着人工操作误差、生产过程不透明等问题。而建材生产智能化系统将通过自动化、信息化和智能化的手段,优化生产流程,提高生产效率,降低成本,同时保证产品质量的稳定性。
系统前台通过JSP页面展示,后台使用SSM框架,数据库采用目前流行的开源关系型数据库MYSQL。在前台的技术使用上,使用了目前流行的vue.js,让页面展现得更加的整齐漂亮。
关键字:建材生产智能化系统;SSM;MySQL
Design of Intelligent System for Building Materials Production
Abstract
In today's construction industry, the demand for intelligent production systems is growing day by day. In order to meet this demand, the design of an intelligent system for building materials production has been proposed. This system aims to improve the efficiency, quality, and sustainability of building materials production through advanced technological means.
The introduction of intelligent systems will bring revolutionary changes to the production of building materials. Traditional production methods often face problems such as manual operation errors and opaque production processes. The intelligent system for building materials production will optimize the production process, improve production efficiency, reduce costs, and ensure the stability of product quality through automation, informatization, and intelligent means.
The front-end of the system is displayed through JSP pages, the back-end uses the SSM framework, and the database uses the popular open-source relational database MYSQL. In terms of front-end technology, the currently popular Vue.js is used to make the page appear more neat and beautiful.
Keywords:Intelligent system for building material production; SSM; MySQL
1 绪论
1.1 研究背景与意义
在当前建筑行业快速发展的背景下,建材生产面临着提高效率、保证质量、降低成本等多方面的挑战。为了应对这些挑战,建材生产智能化系统应运而生。
该系统的设计具有重要意义。它不仅能够实现生产过程的自动化和智能化,提高生产效率和产品质量,还可以降低人力成本和资源消耗。此外,智能化系统还能提供实时监控和数据分析,帮助企业做出科学决策,优化生产管理。同时,符合环保要求的设计有助于减少环境污染,推动建材行业的可持续发展。综上所述,建材生产智能化系统的研究和应用对于提升企业竞争力、促进行业发展具有积极的推动作用。
在国内,建材生产智能化系统设计的研究得到了一定的关注和成果。以下是国内研究现状的几个方面:
生产过程自动化:研究者们关注如何通过自动化技术,实现建材生产过程的智能化和自动化控制,提高生产效率和质量。
数据分析与优化:一些研究致力于利用大数据分析和优化算法,对建材生产过程中的数据进行挖掘和分析,以优化工艺流程、降低能耗和提高产品质量。
机器视觉和智能检测:有研究聚焦于机器视觉和智能检测技术的应用,通过图像处理和模式识别等方法,实现建材产品的质量检测和缺陷识别。
物联网技术应用:部分研究关注如何利用物联网技术,在建材生产过程中实现设备的互联互通,提升生产线的监控和管理水平。
国外研究现状
在国外,建材生产智能化系统设计的研究也取得了一些进展。以下是国外研究现状的几个方面:
人工智能和机器学习:研究者们关注如何利用人工智能和机器学习技术,对建材生产过程进行智能化控制和优化,提高生产效率和产品质量。
自动化设备和机器人应用:一些研究致力于开发和应用自动化设备和机器人技术,实现建材生产线的自动化操作和灵活调整。
虚拟现实和增强现实:有研究聚焦于虚拟现实和增强现实技术的应用,通过模拟和可视化手段,提升建材生产过程中的设计、调试和培训效果。
可持续生产和绿色技术:部分研究关注如何通过可持续生产和绿色技术,实现建材生产过程的环境友好和资源节约,推动可持续发展。
综上所述,国内外关于建材生产智能化系统设计的研究现状不同,国内研究主要关注生产过程自动化和数据分析优化,而国外研究更加注重人工智能、自动化设备、虚拟现实和绿色技术的应用。这些研究成果为本论文的开展提供了借鉴和参考,同时也表明该领域仍然具有较大的研究空间和发展潜力。
本文共分为六章,章节内容安排如下:
第一章为绪论,此章节对所设计和实现的系统的背景、意义和状况以及意义进行详细的论述以及说明,同时进行了论文整体框架的结构的简要介绍。
第二章为系统需求分析,章节所做的主要的工作是对系统进行了技术、经济和操作方面可行性的分析;对系统实行了总体功能的需求、用例分析。
第三章为系统的总体设计,主要是对系统的功能结构进行设计,并对系统数据库的概念结构以及物理结构的设计进行了分析。
第四章就是对系统的实现,根据系统功能的划分,分别的对系统所需要实现的生产员用户、物料员用户、管理员功能进行了分析和说明。
第五章:系统测试。主要对系统的部分界面进行测试并对主要功能进行测试
2 建材生产智能化系统系统分析
系统需求分析是系统开发的一个关键环节,它在系统的设计和实现上起到了一个承上启下的位置。系统需求分析是对所需要做的系统进行一个需求的分析,如果分析的准确可以精准的解决现实中碰到的问题。如果分析不到位会影响后期系统的实现。一个系统的优秀程度需求分析也是占据了非常大的比例,如果需求分析不到位,后面的系统设计要实现就是一个偏离导航的设计。
系统可行行分析是对系统对系统可行性进行一个探讨。在探讨系统的可行性上我们主要从技术上的可行性和经济上的可行性以及法律层面的可行性上进行分析,如果三个层面度通过,我们则认为系统是比较可行的。
2.1.1 技术可行性分析
建材生产智能化系统设计与实现是一个基于SSM建材生产智能化系统,我们在实现这个系统所采用的技术方案是基于Java的 Web实现方案,系统采用Spring 、SpringMvc、Mybatis方案来实现。SSM框架是一个非常成熟的框架、Java从97年诞生到现在经历了野蛮的生长,Java在各个领域度是有做非常成熟的解决方案,如电信、银行、电商等。SSM又是一套快速整个项目的开箱即用的技术方案。所以采用基于SSM方式来实现本系统是一个非常成熟有简单的技术方案。技术可行性上是非常可行的。
从经济可行性上看项目在开发阶段需要一台开发PC,在生产阶段需要web服务器和数据库服务器。一台个人PC从经济上来看也不是太多问题,在后期的系统部署生产上来说,服务器的投入也不会过高,在经济层面上是一个比较可行的。
系统从法律层面上来没有对第三方有其他放有法律层面的问题,系统数据库采用的Mysql 开源社区数据库、框架采用的是开源的SSM。系统资讯和相关内容也是呵呵法律层面的。在源码的管理上采用git开源进行管理,所以在法律可行性上是成立的。
建材生产智能化系统划分为了生产员用户模块,物料员用户模块和管理员模块这三大部分。
生产员用户模块:
- 后台首页:这是生产员用户登录系统后看到的第一个页面,它提供了一个整体概览,包括关键生产数据、通知和提醒等信息。生产员可以快速了解生产进度、任务状态和重要指标。
- 生产任务管理:该功能允许生产员查看、分配和跟踪生产任务。他们可以接收任务分配、更新任务进度、标记完成情况,并与其他相关部门或人员进行沟通和协调。
- 生产计划管理:生产员可以使用此功能来规划和管理生产计划。他们可以制定生产批次、安排生产时间表、设置资源分配,并根据需求和产能进行优化。
- 生产过程管理:过这个功能,生产员可以实时监控生产过程中的各个环节。他们可以查看设备状态、工艺参数、质量控制点等,及时发现并解决可能出现的问题,确保生产过程的顺利进行。
- 生产报告管理:生产员可以生成和查看各种生产报告,如生产日报、周报、月报等。这些报告提供了有关生产绩效、质量数据、成本分析等信息,帮助生产员进行数据分析和决策。
- 物料消耗管理:该功能用于管理和控制生产过程中的物料消耗。生产员可以记录物料的使用情况、监控库存水平、进行物料申请和领料,以确保生产所需物料的充足供应,并避免不必要的浪费。
物料员用户管理模块:
- 后台首页:物料员用户登录后的起始页面,提供物料管理相关的重要信息概览,如库存水平、待处理任务等。
- 生产过程管理:物料员可以监控生产过程中的物料使用情况,确保及时供应所需物料,并协调与生产部门的物料交接。
- 物料库存管理:用于管理和跟踪物料的库存数量、位置和状态。物料员可以进行入库、出库操作,更新库存数据,并设置库存预警。
- 采购订单管理:物料员负责创建、跟踪和管理采购订单。他们可以与供应商沟通,确保物料按时按质到货。
- 物料消耗管理:此功能帮助物料员统计和分析物料的消耗情况,以便进行成本控制和优化物料使用效率。
- 协调供应链管理:与供应商建立紧密的合作关系,协调物料的供应和运输,以确保生产过程的顺利进行。
管理员模块:
- 后台首页:作为管理员登录系统后的起始页面,后台首页提供系统整体状态的概览,包括关键数据的展示、重要通知和警示信息等,帮助管理员快速了解系统的运行情况。
- 系统用户管理:管理员负责管理系统中的用户账户,包括创建、编辑、删除用户,设置用户角色和权限,确保系统的安全性和合规性。
- 生产任务管理:管理员可以对生产任务进行分配、跟踪和监控。他们可以查看任务的进度、分配责任人,并协调相关资源,以确保生产任务按时完成。
- 生产计划管理:管理员参与生产计划的制定和调整。他们可以根据市场需求、产能状况等因素,合理安排生产计划,并对计划执行情况进行跟踪和评估。
- 生产过程管理:通过该功能,管理员可以实时监控生产过程中的关键参数和设备状态,及时发现异常情况并采取相应措施,保证生产过程的顺利进行。
- 生产报告管理:管理员负责生成和管理生产报告,包括生产数据的汇总、分析和报表生成,为管理层提供决策支持。
- 物料库存管理:管理员需要监控物料的库存水平,进行物料的入库、出库和盘点管理,确保物料的充足供应并避免库存积压。
- 采购订单管理:管理员与采购部门协作,管理采购订单的创建、审批和跟踪,以保证生产所需原材料的及时采购和到货。
- 物料消耗管理:该功能帮助管理员分析和控制物料的消耗情况,采取措施降低成本,提高物料利用效率。
- 协调供应链管理:管理员与供应链各方(如供应商、物流服务商等)进行沟通和协调,确保供应链的顺畅运作,以支持生产活动的顺利进行。
- 权限管理:这是管理员的核心职责之一,他们负责设置和管理系统内不同用户的权限,确保数据的安全性和保密性。
建材生产智能化系统的非功能性需求比如建材生产智能化系统的安全性怎么样,可靠性怎么样,性能怎么样,可拓展性怎么样等。具体可以表示在如下3-1表格中:
表3-1建材生产智能化系统非功能需求表
安全性 | 主要指建材生产智能化系统数据库的安装,数据库的使用和密码的设定必须合乎规范。 |
可靠性 | 可靠性是指建材生产智能化系统能够按照用户提交的指示进行操作,经过测试,可靠性90%以上。 |
性能 | 性能是影响建材生产智能化系统占据市场的必要条件,所以性能最好要佳才好。 |
可扩展性 | 比如数据库预留多个属性,比如接口的使用等确保了系统的非功能性需求。 |
易用性 | 用户只要跟着建材生产智能化系统的页面展示内容进行操作,就可以了。 |
可维护性 | 建材生产智能化系统开发的可维护性是非常重要的,经过测试,可维护性没有问题 |
2.3 系统用例分析
建材生产智能化系统的完整UML用例图分别是图2-1、图2-2和图2-3。
图2-1就是生产员用户角色的用例展示。
图2-1 建材生产智能化系统生产员用户角色用例图
图2-2就是物料员用户角色的用例展示。
图2-2 建材生产智能化系统物料员用户角色用例图
图2-3就是管理员角色的用例展示。
图2-3 建材生产智能化系统管理员角色用例图
2.4 系统流程和逻辑
系统业务流程图,如图所示:
图2-4登录流程图
图2-5注册信息流程图
图2-6添加信息流程图
本章主要通过对建材生产智能化系统的可行性分析、功能需求分析、系统用例分析、系统流程分析,确定整个建材生产智能化系统要实现的功能。同时也为建材生产智能化系统的代码实现和测试提供了标准。
3 建材生产智能化系统总体设计
3.1系统结构设计
软件系统的功能是多样的,在软件设计的过程中分层进行的思维是极为重要的,这样的思维可以在软件开发的过程中很大程度降低层之间的耦合度,这一点是符合“低耦合、高内聚”的软件设计原则的。因此,可以把建材生产智能化系统划分为显示层、数据层和业务层。在系统的架构中,为了方便上层调用完成相应的功能,每个层次都会为其对应的上层提供相应的接口。
系统结构图如下所示。
图3-1系统结构图
1.显示层
此层主要是为用户提供计算机交互的UI界面,它根据用户的相应操作来提供相应的逻辑处理。
2.数据库层
数据库不仅是对软件所涉及的实体映射,而且也是系统读取和处理数据的关键所在。本系统的整个操作流程设计都是围绕着数据库里面的数据所展开的。
3.业务层
主要是通过系统的业务层中的业务逻辑来实现业务需求,依据相应的需求,剖析实现的策略和对应的业务逻辑,其优劣,在很大程度上决定了软件的质量,所以,整个系统成败的主要原因在于业务的逻辑实现。
3.2系统功能模块设计
本章主要讨论的内容包括建材生产智能化系统的功能模块设计、数据库系统设计。
3.2.1整体功能模块设计
在上一章节中主要对系统的功能性需求和非功能性需求进行分析,并且根据需求分析了本建材生产智能化系统中的用例。那么接下来就要开始对本建材生产智能化系统的架构、主要功能和数据库开始进行设计。建材生产智能化系统根据前面章节的需求分析得出,其总体设计模块图如图3-2所示。
图3-2建材生产智能化系统功能模块图
3.3 数据库设计
数据库设计一般包括需求分析、概念模型设计、数据库表建立三大过程,其中需求分析前面章节已经阐述,概念模型设计有概念模型和逻辑结构设计两部分。
3.3.1 数据库概念结构设计
下面是整个建材生产智能化系统中主要的数据库表E-R实体关系图。
(1)管理员实体属性图如下图4-3所示
图3-3管理员实体属性图
(2) 订单信息实体属性如下图3-4所示
图3-4采购订单信息实体属性图
(3)物料库存实体属性如下图3-5所示
图3-5物料库存实体属性图
(4)用户注册实体属性如下图3-6所示
图4-6 用户注册实体属性图
将数据库概念设计的E-R图转换为关系数据库。在关系数据库中,数据关系由数据表组成,但是表的结构表现在表的字段上。
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 用户编号: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 更新时间: |
表coordinate_supply_chain (协调供应链)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | coordinate_supply_chain_id | int | 10 | 0 | N | Y | 协调供应链ID | |
2 | material_clerk | int | 10 | 0 | Y | N | 0 | 物料员 |
3 | name_of_material_handler | varchar | 64 | 0 | Y | N | 物料员姓名 | |
4 | material_number | varchar | 64 | 0 | Y | N | 物料编号 | |
5 | material_name | varchar | 64 | 0 | Y | N | 物料名称 | |
6 | material_category | varchar | 64 | 0 | Y | N | 物料类别 | |
7 | material_specifications | varchar | 64 | 0 | Y | N | 物料规格 | |
8 | order_number | varchar | 64 | 0 | Y | N | 订单编号 | |
9 | order_name | varchar | 64 | 0 | Y | N | 订单名称 | |
10 | supplier | varchar | 64 | 0 | Y | N | 供应商 | |
11 | purchase_quantity | varchar | 64 | 0 | Y | N | 采购数量 | |
12 | coordination_content | text | 65535 | 0 | Y | N | 协调内容 | |
13 | communication_situation | text | 65535 | 0 | Y | N | 沟通情况 | |
14 | communication_results | text | 65535 | 0 | Y | N | 沟通结果 | |
15 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
16 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | material_clerk_user_id | int | 10 | 0 | N | Y | 物料员用户ID | |
2 | material_employee_number | varchar | 64 | 0 | N | N | 物料员工号 | |
3 | name_of_material_handler | varchar | 64 | 0 | Y | N | 物料员姓名 | |
4 | examine_state | varchar | 16 | 0 | N | N | 已通过 | 审核状态 |
5 | user_id | int | 10 | 0 | N | N | 0 | 用户ID |
6 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
7 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | material_consumption_id | int | 10 | 0 | N | Y | 物料消耗ID | |
2 | production_operator | int | 10 | 0 | Y | N | 0 | 操作生产员 |
3 | producers_name | varchar | 64 | 0 | Y | N | 生产员姓名 | |
4 | production_date | date | 10 | 0 | Y | N | 生产日期 | |
5 | production_line_number | varchar | 64 | 0 | Y | N | 生产线号 | |
6 | material_clerk | int | 10 | 0 | Y | N | 0 | 物料员 |
7 | name_of_material_handler | varchar | 64 | 0 | Y | N | 物料员姓名 | |
8 | consumable_materials | varchar | 64 | 0 | Y | N | 消耗物料 | |
9 | material_specifications | varchar | 64 | 0 | Y | N | 物料规格 | |
10 | consumption_quantity | varchar | 64 | 0 | Y | N | 消耗数量 | |
11 | consumption_situation | text | 65535 | 0 | Y | N | 消耗情况 | |
12 | material_situation | text | 65535 | 0 | Y | N | 物料情况 | |
13 | examine_state | varchar | 16 | 0 | N | N | 未审核 | 审核状态 |
14 | examine_reply | varchar | 16 | 0 | Y | N | 审核回复 | |
15 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
16 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | material_inventory_id | int | 10 | 0 | N | Y | 物料库存ID | |
2 | material_clerk | int | 10 | 0 | Y | N | 0 | 物料员 |
3 | name_of_material_handler | varchar | 64 | 0 | Y | N | 物料员姓名 | |
4 | material_number | varchar | 64 | 0 | Y | N | 物料编号 | |
5 | material_name | varchar | 64 | 0 | Y | N | 物料名称 | |
6 | material_category | varchar | 64 | 0 | Y | N | 物料类别 | |
7 | material_specifications | varchar | 64 | 0 | Y | N | 物料规格 | |
8 | material_inventory | int | 10 | 0 | Y | N | 0 | 物料库存 |
9 | inventory_situation | text | 65535 | 0 | Y | N | 库存情况 | |
10 | procurement_plan | text | 65535 | 0 | Y | N | 采购计划 | |
11 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
12 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | production_plan_id | int | 10 | 0 | N | Y | 生产计划ID | |
2 | responsible_production_personnel | int | 10 | 0 | Y | N | 0 | 负责生产员 |
3 | producers_name | varchar | 64 | 0 | Y | N | 生产员姓名 | |
4 | plan_name | varchar | 64 | 0 | Y | N | 计划名称 | |
5 | planned_time | varchar | 64 | 0 | Y | N | 计划时间 | |
6 | plan_indicators | varchar | 64 | 0 | Y | N | 计划指标 | |
7 | plan_content | text | 65535 | 0 | Y | N | 计划内容 | |
8 | planned_progress | text | 65535 | 0 | Y | N | 计划进度 | |
9 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
10 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | production_process_id | int | 10 | 0 | N | Y | 生产过程ID | |
2 | production_operator | int | 10 | 0 | Y | N | 0 | 操作生产员 |
3 | producers_name | varchar | 64 | 0 | Y | N | 生产员姓名 | |
4 | production_date | date | 10 | 0 | Y | N | 生产日期 | |
5 | production_line_number | varchar | 64 | 0 | Y | N | 生产线号 | |
6 | device_name | varchar | 64 | 0 | Y | N | 设备名称 | |
7 | equipment_brand | varchar | 64 | 0 | Y | N | 设备品牌 | |
8 | equipment_model | varchar | 64 | 0 | Y | N | 设备型号 | |
9 | production_situation | text | 65535 | 0 | Y | N | 生产情况 | |
10 | usage | text | 65535 | 0 | Y | N | 使用情况 | |
11 | process_flow | text | 65535 | 0 | Y | N | 工艺流程 | |
12 | device_status | text | 65535 | 0 | Y | N | 设备状态 | |
13 | material_consumption | text | 65535 | 0 | Y | N | 材料消耗 | |
14 | abnormal_situation | text | 65535 | 0 | Y | N | 异常情况 | |
15 | resolve_the_situation | text | 65535 | 0 | Y | N | 解决情况 | |
16 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
17 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | production_report_id | int | 10 | 0 | N | Y | 生产报告ID | |
2 | production_operator | int | 10 | 0 | Y | N | 0 | 操作生产员 |
3 | producers_name | varchar | 64 | 0 | Y | N | 生产员姓名 | |
4 | production_line_number | varchar | 64 | 0 | Y | N | 生产线号 | |
5 | production_name | varchar | 64 | 0 | Y | N | 生产名称 | |
6 | production_time | datetime | 19 | 0 | Y | N | 生产时间 | |
7 | production_quantity | varchar | 64 | 0 | Y | N | 生产数量 | |
8 | quality_index | text | 65535 | 0 | Y | N | 质量指标 | |
9 | report_content | text | 65535 | 0 | Y | N | 报告内容 | |
10 | production_results | text | 65535 | 0 | Y | N | 生产结果 | |
11 | report_file | varchar | 255 | 0 | Y | N | 报告文件 | |
12 | examine_state | varchar | 16 | 0 | N | N | 未审核 | 审核状态 |
13 | examine_reply | varchar | 16 | 0 | Y | N | 审核回复 | |
14 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
15 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
表production_staff_users (生产员用户)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | production_staff_users_id | int | 10 | 0 | N | Y | 生产员用户ID | |
2 | production_employee_number | varchar | 64 | 0 | N | N | 生产员工号 | |
3 | producers_name | varchar | 64 | 0 | Y | N | 生产员姓名 | |
4 | examine_state | varchar | 16 | 0 | N | N | 已通过 | 审核状态 |
5 | user_id | int | 10 | 0 | N | N | 0 | 用户ID |
6 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
7 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | production_tasks_id | int | 10 | 0 | N | Y | 生产任务ID | |
2 | responsible_production_personnel | int | 10 | 0 | Y | N | 0 | 负责生产员 |
3 | producers_name | varchar | 64 | 0 | Y | N | 生产员姓名 | |
4 | task_name | varchar | 64 | 0 | Y | N | 任务名称 | |
5 | task_indicators | varchar | 64 | 0 | Y | N | 任务指标 | |
6 | task_time | varchar | 64 | 0 | Y | N | 任务时间 | |
7 | task_type | varchar | 64 | 0 | Y | N | 任务类型 | |
8 | task_content | text | 65535 | 0 | Y | N | 任务内容 | |
9 | task_requirements | text | 65535 | 0 | Y | N | 任务要求 | |
10 | production_progress | text | 65535 | 0 | Y | N | 生产进度 | |
11 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
12 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | purchase_order_id | int | 10 | 0 | N | Y | 采购订单ID | |
2 | material_clerk | int | 10 | 0 | Y | N | 0 | 物料员 |
3 | name_of_material_handler | varchar | 64 | 0 | Y | N | 物料员姓名 | |
4 | material_number | varchar | 64 | 0 | Y | N | 物料编号 | |
5 | material_name | varchar | 64 | 0 | Y | N | 物料名称 | |
6 | material_category | varchar | 64 | 0 | Y | N | 物料类别 | |
7 | material_specifications | varchar | 64 | 0 | Y | N | 物料规格 | |
8 | order_number | varchar | 64 | 0 | Y | N | 订单编号 | |
9 | order_name | varchar | 64 | 0 | Y | N | 订单名称 | |
10 | supplier | varchar | 64 | 0 | Y | N | 供应商 | |
11 | purchase_quantity | varchar | 64 | 0 | Y | N | 采购数量 | |
12 | purchase_price | varchar | 64 | 0 | Y | N | 采购价格 | |
13 | total_order_price | varchar | 64 | 0 | Y | N | 订单总价 | |
14 | procurement_description | text | 65535 | 0 | Y | N | 采购说明 | |
15 | procurement_requirements | text | 65535 | 0 | Y | N | 采购要求 | |
16 | examine_state | varchar | 16 | 0 | N | N | 未审核 | 审核状态 |
17 | examine_reply | varchar | 16 | 0 | Y | N | 审核回复 | |
18 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
19 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | sensitive_vocabulary_id | int | 10 | 0 | N | Y | 敏感词汇ID | |
2 | sensitive_vocabulary | varchar | 64 | 0 | Y | N | 敏感词汇 | |
3 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
4 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 文件类型 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | | 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 | 会员折扣 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 更新时间: |
整个建材生产智能化系统的需求分析主要对系统总体架构以及功能模块的设计,通过建立E-R模型和数据库逻辑系统设计完成了数据库系统设计。
4 建材生产智能化系统详细设计与实现
建材生产智能化系统的详细设计与实现主要是根据前面的建材生产智能化系统的需求分析和建材生产智能化系统的总体设计来设计页面并实现业务逻辑。主要从建材生产智能化系统界面实现、业务逻辑实现这两部分进行介绍。
管理员通过用户名和密码,密码填写完成后选择提交,管理员登录成功后进入到系统操作界面,可以对首页、系统用户、生产任务管理、生产计划管理、生产过程管理、生产报告管理、物料库存管理、采购订单管理、物料消耗管理、协调供应链管理、权限管理等功能模块进行相对应操作。如下图所示。
图4-1管理员登录页面
登录关键代码如下所示。
@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<>();
图4-2管理员系统功能界面图
系统用户管理:管理员可以对系统中所有的用户角色进行管理,包含了管理员、生产员用户、物料员用户这三种角色,可以对用户角色进行查询、重置、添加和删除。如果需要添加新的用户,点击页面中的“添加”按钮根据提示输入上用户信息,点击“提交”以后在对应的用户界面就可以看到新增的用户信息;如果点击用户后面的“删除”按钮则可以直接删除某一用户,这里以生产员用户为例。如下图所示。
图4-3系统用户管理界面图
系统用户代码如下:
@TableName("user_group")
@Data
@EqualsAndHashCode(callSuper = false)
public class UserGroup implements Serializable {
private static final long serialVersionUID = 968356951391304707L;
}
权限管理:当点击“权限管理”这一菜单的时候,会出现权限列表这个子菜单,可以对这个模块进行增删改查操作。权限管理界面如下图所示。
图4-4权限管理界面图
权限管理关键代码如下:
@PostMapping("/add")
@Transactional
public Map<String, Object> add(HttpServletRequest request) throws IOException {
service.insert(service.readBody(request.getReader()));
return success(1);
}
@Transactional
public Map<String, Object> addMap(Map<String,Object> map){
service.insert(map);
return success(1);
}
注册界面:这块程序首先根据所取得的表单中的用户名查询数据库中是否有相同用户名的记录,如果数据库存在相同的用户名,则提示用户名已存在,否则,打开记录集并添加一条新的记录,然后系统默认要给用户发送注册成功的提醒。
注册流程图如下所示。
图4-5生产员注册流程图
首先生产员用户需要通过输入账号、密码、昵称、邮箱、身份等信息进行账号注册,如下图所示。
图4-6生产员注册界面图
注册关键代码如下所示。
/**
* 注册
* @return
*/ @PostMapping("register")
public Map<String, Object> signUp(HttpServletRequest request) throws IOException {
// 查询用户
Map<String, String> query = new HashMap<>();
Map<String,Object> map = service.readBody(request.getReader());
query.put("username",String.valueOf(map.get("username")));
List list = service.selectBaseList(service.select(query, new HashMap<>()));
if (list.size()>0){
return error(30000, "用户已存在");
}
map.put("password",service.encryption(String.valueOf(map.get("password"))));
service.insert(map);
return success(1);
}
public Map<String,Object> readBody(BufferedReader reader){
BufferedReader br = null;
StringBuilder sb = new StringBuilder("");
try{
br = reader;
String str;
while ((str = br.readLine()) != null){
sb.append(str);
}
br.close();
String json = sb.toString();
return JSONObject.parseObject(json, Map.class);
}catch (IOException e){
e.printStackTrace();
}finally{
if (null != br){
try{
br.close();
}catch (IOException e){
e.printStackTrace();
}
}
}
return null;
}
public void insert(Map<String,Object> body){
E entity = JSON.parseObject(JSON.toJSONString(body),eClass);
baseMapper.insert(entity);
log.info("[{}] - 插入操作:{}",entity);
}
个人信息:生产员用户点击右上角个人信息,可以对个人信息进行管理,如下图所示。
图4-7个人信息界面图
密码修改:用户使用该系统注册完成后,用户对登录密码有修改需求时,系统也可以提供用户修改密码权限。系统中所有的操作者能够变更自己的密码信息,执行该功能首先必须要登入系统,然后选择密码变更选项以后在给定的文本框中填写初始密码和新密码来完成修改密码的操作。在填写的时候,假如两次密码填写存在差异,那么此次密码变更操作失败。密码修改界面如下图所示。
图4-8密码修改界面图
生产过程管理:点击“生产过程管理”这一菜单会显示生产过程列表、生产过程添加这两个子菜单,如果想要添加新的生产过程,点击“添加”按钮,输入设备名称、设备型号、使用情况、设备状态、异常情况等信息,点击“提交”按钮就可以添加了,同时可以选择某一条生产过程信息,点击“删除”进行删除。界面如下图所示。
图4-9生产过程列表界面图
图4-10生产过程添加界面图
物料库存管理:点击“物料库存管理”这一菜单会显示物料库存列表、物料库存添加这两个子菜单,如果想要添加新的物料库存,点击“添加”按钮,输入物料员、物料编号、物料类别、物料库存、采购计划等信息,点击“提交”按钮就可以添加了,同时可以选择某一条物料库存信息,点击“删除”进行删除。界面如下图所示。
图4-11 物料库存列表页面
图4-12物料库存添加页面
物料消耗管理:点击“物料消耗管理”这一菜单会显示物料消耗列表这个子菜单,如果想要添加新的物料库存,点击“添加”按钮,输入操作生产员、生产日期、物料员、消耗物料、消耗数量、物料情况、审核回复等信息,点击“提交”按钮就可以添加了。界面如下图所示。
图4-13物料消耗页面
5系统测试
5.1 系统测试用例
系统测试包括:用户登录功能测试、生产报告查看、物料库存列表添加、物料名称搜索、密码修改、采购订单功能测试,如表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)填写采购需求、订单内容,点击进行查询。 |
预期结果 | 查询成功 |
实际结果 | 实际结果与预期结果一致 |
通过编写建材生产智能化系统的测试用例,已经检测完毕用户登录功能测试、生产报告查看、物料库存列表添加、物料名称搜索、密码修改、采购订单功能测试,通过这些测试为建材生产智能化系统的后期推广运营提供了强力的技术支撑。
结论
本文描述了建材生产智能化系统设计与实现的原理和开发过程,该系统是通过SSM框架来搭建后台,中间件使用的是Tomcat服务器,数据库管理平台采用开源的Mysql,前台使用的是JQuery框架,同时使用Validate校验框架,这样就可以减少前端代码的输入量,而且基于JQuery框架的Validat框架使用简单,是流行的前端使用框架,前端使用的主要是Jsp页面展示技术。
在开发前做了许多的准备,在本系统的设计和开发过程中阅览和学习了许多文献资料,从开发这个建材生产智能化系统的过程中我也收获了许许多多宝贵的方法以及设计思路,对系统的开发也起到了很重要的作用,系统的开发技术选用的都是自己比较熟悉的,比如Web、SSM、MYSQL,这些技术都是在以前的学习中学到了,其中许多的设计思路和方法都是在以前不断地学习中摸索出来的经验,其实对于我们来说工作量还是比较大的,但是正是由于之前的积累与准备,才能顺利的完成这个项目,由此看来,积累经验跟做好准备是十分重要的事情。
当然在该系统的设计与实现的过程中也离不开老师以及同学们的帮助,正是因为他们的指导与帮助,我才能够成功的在预期内完成了这个系统。同时在这个过程当中我也收获了很多东西,此系统也有需要改进的地方,但是由于专业知识的浅薄,并不能做到十分完美,希望以后有机会可以让其真正的投入到使用之中。
参考文献
[1]粟梁.基于Java的汽车租赁管理系统[J].电脑编程技巧与维护,2024,(01):43-45+52.DOI:10.16184/j.cnki.comprg.2024.01.035.
[2]Juwana I ,Sodri A ,Muttil N , et al.Potential Pollution Loads of the Cikembar Sub-Watershed to the Cicatih River, West Java, Indonesia[J].Water,2024,16(2):
[3]Retnaningsih T S ,R.B. S ,Hadiyanto H , et al.The carbon stock potential of the restored mangrove ecosystem of Pasarbanggi, Rembang, Central Java[J].Marine Environmental Research,2024,193106257-.
[4]袁爱平,陈畅,孙士兵等.基于SSM框架的高校学生信息管理系统设计与实现[J].工业控制计算机,2023,36(12):127-129.
[5]苏婉怡,揣小龙,刘美瑜等.基于Java技术的实验室管理系统设计与实现[J].无线互联科技,2023,20(23):58-60.
[6]单厚信,刘舒心,程文远等.基于SSM架构的图书资料管理系统设计与实现[J].现代信息科技,2023,7(23):46-51.DOI:10.19850/j.cnki.2096-4706.2023.23.010.
[7]闫凤琴,李汶洋.基于SSM的防诈骗警民协同防护平台的设计与实现[J].中国新通信,2023,25(23):140-142.
[8]D F M P ,D A N ,Zulfakriza , et al.Moho Depth Estimation using Receiver Function beneath Mt. Manglayang Area, West Java, Indonesia[J].IOP Conference Series: Earth and Environmental Science,2023,1288(1):
[9]Abdoellah S O ,Suparman Y ,Safitri I K , et al.Food Security of Urban Agricultural Households in the Area of North Bandung, West Java, Indonesia[J].Sustainability,2023,15(24):
[10]Sigit A ,Koyama M ,Harada M .Flood Risk Assessment Focusing on Exposed Social Characteristics in Central Java, Indonesia[J].Sustainability,2023,15(24):
[11]宋晓燕,杨芬.Java程序设计语言的分层教学实践[J].电子技术,2023,52(11):182-183.
[12]田玉昆.基于Java Web技术的手机销售网站的设计与实现[J].电脑知识与技术,2023,19(32):47-49.DOI:10.14004/j.cnki.ckt.2023.1766.
[13]刘方磊.基于SSM框架的旅游大数据分析系统设计与实现[J].中国新技术新产品,2023,(21):22-25.DOI:10.13612/j.cnki.cntp.2023.21.002.
[14]张国芳.Java编程语言在计算机软件开发中的应用方向分析[J].信息记录材料,2023,24(11):138-141.DOI:10.16009/j.cnki.cn13-1295/tq.2023.11.042.
[15]赵进步,袁慧.基于SSM框架的“云节”系统设计与实现[J].电脑编程技巧与维护,2023,(10):90-92.DOI:10.16184/j.cnki.comprg.2023.10.021.
[16]王敏.基于SSM的高校学生综合测评管理系统设计与实现[J].电脑知识与技术,2023,19(29):59-62+70.DOI:10.14004/j.cnki.ckt.2023.1530.
[17]岳峰,段政伟.基于SSM的IMSI与人像采集比对系统设计与实现[J].工业控制计算机,2023,36(07):96-97.
[18]田斌.基于SSM框架的宠物医院系统设计[J].无线互联科技,2023,20(14):69-71.
[19]赵志文,郝东来,李民靖.基于SSM框架的无人机监管系统[J].现代计算机,2023,29(12):84-88.
[20]滕洋,科技中介服务项目信息智能化管理系统.安徽省,颍上富元生产力促进中心有限公司,2020-12-01.
致 谢
逝者如斯夫,不舍昼夜。转眼间,大学生会员活便已经接近尾声,人面对着离别与结束,总是充满着不舍与茫然,我亦如此,仍记得那年秋天,我迫不及待的提前一天到了学校,面对学校巍峨的大门,我心里充满了期待:这里,就是我新生活的起点吗?那天,阳光明媚,学校的欢迎仪式很热烈,我面对着一个个对着我微笑的同学,仿佛一缕缕阳光透过胸口照进了我心里,同时,在那天我认识可爱的室友,我们携手共同度过了这难忘的两年。如今,我望着这篇论文的致谢,不禁又要问自己:现在,我们就要说再见了吗?
感慨莫名,不知所言。遥想当初刚来学校的时候,心里总是想着工科学校会过于板正,会缺乏一些柔情,当时心里甚至有一点点排斥,但是随着我对学校的慢慢认识与了解,我才认识到了她的美丽,她的柔情,并且慢慢的喜欢上了这个校园,但是时间太快了,快到我还没有好好体会她的美丽便要离开了,但是她带给我的回忆,永远不会离开我,也许真正离开那天我的眼里会满含泪水,我不是因为难过,我只是想将她的样子映在我的泪水里,刻在我的心里。最后,感谢我的老师们,是你们教授了我们知识与做人的道理;感谢我的室友们,是你们陪伴了我如此之久;感谢每位关心与支持我的人。
少年,追风赶月莫停留,平荒尽处是春山。
标签:物料,10,varchar,24838,系统,源码,64,毕业设计,生产 From: https://blog.csdn.net/weixin_BYSJ1987/article/details/145157514点赞+收藏+关注 →私信领取本源代码、数据库