21世纪的今天,随着社会的不断发展与进步,人们对于信息科学化的认识,已由低层次向高层次发展,由原来的感性认识向理性认识提高,管理工作的重要性已逐渐被人们所认识,科学化的管理,使信息存储达到准确、快速、完善,并能提高工作管理效率,促进其发展。
农产品供应链管理系统通过科学的管理方式、便捷的服务提高了工作效率,减少了数据存储上的错误和遗漏。农产品供应链管理系统使用Java语言,采用基于SSM框架、技术进行开发,使用 MyEclipse 2017 CI 10 编译器编写,数据方面主要采用的是微软的MySQL关系型数据库来作为数据存储媒介,配合前台HTML+CSS 技术完成系统的开发。
关键词:农产品供应链管理系统;MySQL;SSM框架
SSM Agricultural Product Supply Chain Management System
Abstract
Today in the 21st century, with the continuous development and progress of society, people's understanding of information science has developed from low to high levels, from intuitive understanding to rational understanding, and the importance of management work has gradually been recognized by people. Scientific management enables information storage to achieve accuracy, speed, and completeness, and can improve work management efficiency and promote its development.
The agricultural product supply chain management system has improved work efficiency and reduced errors and omissions in data storage through scientific management methods and convenient services. The agricultural product supply chain management system is developed using Java language, SSM framework and technology, and MyEclipse 2017 CI 10 compiler. The data is mainly stored in Microsoft's MySQL relational database, and the system is developed in conjunction with front-end HTML+CSS technology.
Keywords: Agricultural product supply chain management system; MySQL; SSM Framework
目 录
1 绪论
1.1 选题背景
随着农业现代化进程的推进,农产品生产、加工、流通等环节逐渐实现标住化、信息化和智能化,这对农产品供应链提出了更高的要求,要求其具备更强的整合能力、更高的透明度和更低的成本。随着人们生活水平的提高,消费者对农产品的需求日益多样化、个性化,对农产品的新鲜度、安全性、品质等方面的要求也越来越高,农产品供应链平台可以通过数据分析和精细化运营,更好地满足消费者的需求。
电子商务的快速发展为农产品供应链平台提供了良好的外部环境。通过电子商务平台。可以实现农产品的在线交易、物流配送、信息追溯等功能,大大提高农产品流通的效率和透明度,政府对农业信息化、农产品电子商务等给予了大力支持,出台了一系列相关政策,为农产品供应链平台的发展提供了有力保障。
1.2 研究意义
理论价值:农产品供应链平台的研究有助于完善农产品供应链理论体系,推动供应链管理、电子商务、农业信息化等相关学科的交叉融合,为农产品流通领域的理论创新提供有力支撑。
实践意义:农产品供应链平台的发展能够有效促进农业产业升级和农民增收,推动农产品流通的现代化和市场化,提高农产品供应链的整体效率和竞争力。同时,通过农产品供应链平台的建设和运营,还可以带动相关产业的发展,如物流配送、信息技术服务等,进一步推动农业与工业、服务业的深度融合。
综上所述,农产品供应链平台的研究不仅有助于推动农业领域的理论创新,还具有重要的实践意义,对于促进农业现代化、满足消费升级需求.推动电子商务发展等方面都具有积极的作用。
1.3论文结构与章节安排
论文将分层次进行编排,除去论文摘要致谢文献参考部分,论文主要架构如下:
第一章:绪论。主要介绍了课题研究的背景与意义和论文结构与章节安排。
第二章:相关技术介绍。主要详情介绍了开发本系统使用的技术进行详细介绍。
第三章:系统分析。主要从系统的可行性和用户的功能进行需求分析。
第四章:系统总体设计。主要对系统框架、系统功能模块、数据库进行功能设计。
第五章:系统详细设计与实现。主要介绍了系统框架搭建、系统界面的实现。
第六章:系统测试。主要对系统的部分界面进行测试并对主要功能进行测试。
第七章:总结。主要对系统的设计工作进行总结。
2 系统开发技术
这部分内容主要介绍本系统使用的技术,包括使用的工具,编程的语言等内容。
2.1开发环境介绍
1.软件体系结构方案:采用B/S模式,B/S代表的是服务器端由web服务器发放,客户端由浏览器接收的系统,它的前台是html语言,由浏览器解释。B/S结构可以由web服务器能够解释的脚本语言如jsp、php、asp、JavaScript。
2.操作系统方案:Windows 7(旗舰版)操作系统,该系统可以兼容需要的软件,并且具有良好的运行速度,界面良好。
3.后台数据库:选用Mysql。Mysql旨在通过数据库加密、更加安全的默认设置、加强的密码政策和细化许可控制、及加强的安全模型等特性,为企业数据提供最高级别的安全性。
4.开发工具:选用Myeclipse10
5.开发语言:Java语言。
6.开发技术:SSM+html+css+js技术。
2.2 Java语言
Java语言在计算机的程序应用过程当中,属于非常重要的一个应用软件,因为它的性能比较高,而且能够应用在多重领域当中,因此该程序在计算机的软件程序应用当中的范围相对来说是比较广泛的。而从专业的技术角度来说,Java程序的应用的实用性也是非常强的,这是因为它与传统的C语言或C++相比没有太大的基本结构的变化,也就是说它的语法结构是相对单一,而且具有稳定的特性,还有更重要的一点是Java程序语言的基本参考对象就是C语言,所以他的程序编写并不是很复杂,而且还能够起到优化工作效率提升系统设计本身的基础功能的作用,因此他也就受到了非常广泛的程序员们的青睐。
在此次进行系统设计开发研究的过程当中,还发现Java程序语言之所以能够得到市场上更多用户的好评和青睐,其根本原因在于他能够具备各种语言的自身独特优点的展现,也就是说它的兼容性是常强的。因此,我们因此我们可以说在任何一个程序的开发过程当中,Java语言程序的应用是必不可少的,它他在程序员进行改动的时候,哪怕是一个程序字母的改动,都可以形成一种特定的程序,这是 Java程序,非常独特的另一个优点。不仅如此,Java源程序的可移植性也是非常大,而且它的安全系数很高,能够通过不同方式进行移植到其他程序当中,而且可以兼容不同程序的系统,在运行的过程当中,其安全系数也是非常强的,能够确保用户在使用网络的过程当中去确保网络的安全,而正是基于这样的可移植性,为程序员节约了很多的系统语言程序的开发设计的时间,这是非常难得的一种自有优势。
2.3 SSM框架
本课题开发的应用程序主要采用的框架技术是SSM,是Java语言的一种框架集合的简称,目前在Java语言方面,主要有两大分支,一个是主攻Java语言,学习了Java基础之后,会有很多Java进阶框架进行学习,主要是针对应用程序后台进行开发设计,另一方面是转行去学习安卓语言,主要是做安卓的前端设计方面,虽然也是Java语言,但是主要去学习安卓平台的各种架构和框架了。但是不管前端应用如何,SSM框架主要是针对服务端方面进行开发的一个主流框架集合。针对于传统的SSH框架的臃肿,配置繁琐,不管是开发还是二次开发都会造成时间上大量的浪费,并且学习上面也不能有效衔接,需要去适应框架的各种设计,而框架设计比较死板,容易出错。SSM框架是当前最流行的,告别了繁琐的配置,让配置更加灵活,让数据操作更加方便,选择SSM框架进行开发感觉是很合适的。
2.4 MYSQL数据库
关系型数据库设计,对于数据库字段类型的设计以及字段长度的设计,都无时无刻的影响着后续程序开发后大量数据操作的运行效率。关系型数据库对不同的字段类型都有解释,本着课题所需的应用程序开发,寻找最适合的关系型数据库,基本上都有考虑。关系型数据库发展至今也有几十年了,优胜劣汰导致到现在还依然存在的关系型数据库其实并不多,基本上也都能满足应用程序的功能所需,所以要从其他方面来进行考虑数据库的选择。从安装维护上面考虑,SQL Server数据库有好几个G的安装包,并且安装过程中会安装很多不需要的功能,非常占用资源。Oracle数据库不比SQL Server安装包小,并且安装也会出现很多问题,对于课题所需来讲,没必要这么麻烦,并且安装还需要各种激活,只有MySQL数据库完全适合,几十兆大小的安装包,运行起来压力不大,毕竟开发电脑上还有很多其他有用的东西,而且完全免费,所以选择了MySQL数据库作为首选数据库。
这部分内容虽然在开发流程中处于最开始的环节,但是它对接下来的设计和实现起着重要的作用,因为系统分析结果的好坏,将直接影响后面环节的开展。
3.1可行性研究
影响系统开发的因素有很多,比如开发成本高就不适合开展,或者是开发时间超过了预期,也不适合开展等等。所以,在正式作出开发决策前,研究系统可行性问题,从经济,时间,操作等角度论证系统是否可以开展。
3.1.1经济可行性
农产品供应链管理系统可以简化工作流程,提供信息处理功能,并可以长期保存数据,在后期的数据查询与编辑中耗时少,提升信息管理效率,其带来的收益比较可观。对于本系统开发,无论是开发需要使用的计算机,还是开发工具等投入的成本很低,计算机是机房的电脑,开发工具是从网上下载安装的,并没有收取费用。
3.1.2时间可行性
农产品供应链管理系统是作为本人毕设项目的一个作品,学院也充分预留了制作时间,并且在每个时间段,都安排了相应的任务,所以根据这个时间安排开展工作,是可以对本系统进行设计完成的。
3.1.3操作可行性
随着电脑的普及,已经有很多人可以独立操作电脑了。而本系统就是在配置了运行环境的电脑上运行,其功能简单,省去了很多繁琐的操作逻辑,使用者通过页面导航可以直接进入功能操作区,所以稍微懂点电脑的人,都可以轻松完成系统的使用。
综上所述,本系统可以开展接下来的工作了。
3.2系统性能分析
为了降低本系统在实际使用中的出错率,就需要分析系统具备的性能。常见的可以评估系统的性能的指标有安全性,易用性,健壮性等。
3.2.1系统易用性
系统提供的信息和服务都有特定的用户群,所以,一个容易操作的系统相比一个不方便使用的系统来讲,用户还是更加青睐于使用方便的系统。所以系统具备易用性就显得非常重要。
3.2.2系统健壮性
系统在与用户进行交互过程中,面对用户的误操作行为,系统应该有相应的处理这种问题的反馈机制,而不是进入系统崩溃状态。系统中设置了很多的功能,在应对系统中某个功能出现异常情况时,系统的其它功能还是可以让用户使用。这就是系统健壮性的体现。
3.2.3系统安全性
保存在系统里面的数据,都是比较重要的系统资源,一旦这些资源泄露,不仅会有财产损失,还会丧失很多客户。所以,系统里面的数据要随时都处于安全的环境中,因此就需要采取措施保证数据安全,比如设置登录功能,使用安全验证技术引导条件用户进入指定页面,而让非条件用户停留在登录页面,不能访问系统。
3.3 系统流程分析
软件开发设计的思想始终贯穿本系统,其开发流程见下图。前期需要进行功能分析,功能设计,还有对系统后台支持数据库的设计,利用编码技术对设计的系统进行实现,然后检测和完善。
图3.1系统开发流程图
访问者之所以可以访问农产品供应链管理系统,主要是其数据库有该访问者的记录信息,这个记录是通过注册进行写入的数据。注册流程见下图。每当访问者进行农产品供应链管理系统注册时,其登记的每条记录都会在系统后台进行逐个判断。这个判断规则是提前设置的。一旦该访问者的登记信息在数据库中保存,即代表该访问者成为农产品供应链管理系统中的一份子。
图3.2 注册流程图
访问者操作系统,前提是需要验证身份,而登录功能的设置就是把本系统的用户引导进入后台操作区,把不是本系统的用户拒之门外。其流程见下图。
图3.3 登录流程图
3.4系统功能分析
在明确系统的用途,以及系统的目标用户群后,可以对本系统的功能进行设置,可以获取调研用户对功能的要求,也可以对市场上同类系统进行分析和总结,得出本系统的功能。
农产品供应链管理系统设置了管理员权限,其用例图见下图。管理员登录进入本人后台之后,管理用户管理、系统管理、生产信息、生产订单管、批发订单、批发信息、零售订单、零售信息等功能模块。
图3.4 管理员用例图
农产品供应链管理系统设置了生产用户权限,其用例图见下图。生产用户查看主页、系统公告、生产信息、生产订单等功能模块。
农产品供应链管理系统设置了批发用户权限,其用例图见下图。批发用户查看主页、系统公告、生产信息、生产订单、批发信息、批发订单等功能模块。
图3.6 批发用户用例图
农产品供应链管理系统设置了批发用户权限,其用例图见下图。批发用户查看主页、系统公告、生产信息、生产订单、批发信息、批发订单等功能模块。
图3.7 零售用户用例图
农产品供应链管理系统设置了农民用户权限,其用例图见下图。农民用户查看主页、系统公告零售信息、零售订单等功能模块。
图3.8农民用户用例图
4 系统设计
当前,系统的类型有很多,从系统呈现的内容来看,系统的类型有社交类,有商业类,有新闻类等。那么,在众多系统类型中,先明确将要设计的系统的类型才是系统设计的首要工作,然后在此基础上明确系统的用户群,功能等,针对这些信息设计出具有独特体验和视觉的系统。如此才能让系统比较具有特色,也能够在众多相似系统中给用户留下深刻印象。
4.1系统目标
本系统在功能制定上,严格参照用户的要求,但是在设计本系统时,也要满足易操作,使用便利的设计要求。由此,设计出一个规范化并且符合用户需求的系统,一定要达到下述系统目标。
第一个系统目标:用户与系统之间的操作方式是基于人机对话,可视化界面的设计除了美观性之外,也具备友好性。可视化界面提供的各类信息符合准确性,可靠性的要求,并能够方便用户灵活查看。
第二个系统目标:用户与系统交互产生的数据,要严格规范的保存在数据库里,无论是后期管理人员查找与管理,都要确保数据安全。
第三个系统目标:实现用户需求的功能。根据对用户的调查得出的功能需求,完成农产品供应链管理系统的设计与实现。
第四个系统目标:在必要环节,对用户登记的数据进行检查,包括数据长度,以及数据输入类型等的检查,发现错误及时反馈,引导用户规范登记数据。常见的有密码修改,注册登录,用户资料填写等环节的数据核验。
第五个系统目标:设计开发本系统,需要尽最大努力,在系统具备易操作的特点外,也要求系统于后期使用中,维护方便,让系统具备易维护的特点。
第六个系统目标:本系统在交付用户使用时,可以达到运行稳定的目标,另外,系统具备安全性,也符合可靠性的条件,用户可以放心使用。
4.2功能结构设计
通过使用农产品供应链管理系统,我们可以实现多种功能,从而满足用户的各种需求。该系统的功能结构如图4-1所示,具有良好的完整性和可靠性。
图4.1 系统功能结构图
4.3数据库设计
相比非关系型数据库来说,目前市场上使用率比较高,并且易于维护的数据库,当数关系型数据库了。这个数据库主要是基于关系模型的方式来对数据信息进行组织。也就是常见的二维表模型。可以说二维表和二维表之间的相互联系就构成了关系型数据库。
4.3.1数据库E-R图
为了更好地保存农产品供应链管理系统产生的数据,就需要在数据库的设计阶段对E-R模型进行建立,以及完成数据库中的表结构的创建。之所以要单独完成数据库的设计,主要有以下几点原因:
第一点:防止代码冗余;
第二点:防止占用过多内存;
第三点:提升数据库的整体性能,方便程序开发以及数据更新;
第四点:保证数据的完整性;
本部分内容主要在于建立本系统的E-R模型,需要先收集数据,然后根据数据库实现的思路,对用户的需求进行分析,这期间需要对实体,属性,还有关系进行标识,为绘制E-R模型做好充足准备。同时,在作图中,也要注意作图规范,
图4.3 实体间关系E-R图
4.3.2 数据库表结构
为了设计出结构合理,性能优良的数据库,在设计数据库时,需要遵循三大范式:
第一范式:确保数据表当中的每列所代表的字段值都不能再进行分解了;
第二范式:在满足第一范式基础上,让数据表中每列与主键相关;
第三范式:在满足第二范式基础上,确保每列数据直接与主键相关,不是间接相关。
从上面的表述中可以看出,这三大范式,在等级上还是有区分的,最低等级的就数第一范式,最高等级的就是第三范式,趋于两者中间的是第二范式。总之,数据库设计按照这三大范式进行,可以简化设计过程,并且还会减少数据冗余,对于数据检索效率的提升也很有帮助。
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 更新时间: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | farmer_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 | contact_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 | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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: |
表production_information (生产信息)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | production_information_id | int | 10 | 0 | N | Y | 生产信息ID | |
2 | production_users | int | 10 | 0 | Y | N | 0 | 生产用户 |
3 | product_batch | varchar | 64 | 0 | Y | N | 产品批次 | |
4 | product_name | varchar | 64 | 0 | Y | N | 产品名称 | |
5 | product_type | varchar | 64 | 0 | Y | N | 产品类型 | |
6 | product_price | int | 10 | 0 | Y | N | 0 | 产品价格 |
7 | product_inventory | int | 10 | 0 | Y | N | 0 | 产品库存 |
8 | product_images | varchar | 255 | 0 | Y | N | 产品图片 | |
9 | product_description | text | 65535 | 0 | Y | N | 产品描述 | |
10 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
11 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | production_orders_id | int | 10 | 0 | N | Y | 生产订单ID | |
2 | production_users | int | 10 | 0 | Y | N | 0 | 生产用户 |
3 | product_batch | varchar | 64 | 0 | Y | N | 产品批次 | |
4 | product_name | varchar | 64 | 0 | Y | N | 产品名称 | |
5 | product_type | varchar | 64 | 0 | Y | N | 产品类型 | |
6 | product_price | varchar | 64 | 0 | Y | N | 产品价格 | |
7 | wholesale_users | int | 10 | 0 | Y | N | 0 | 批发用户 |
8 | order_quantity | int | 10 | 0 | Y | N | 0 | 下单数量 |
9 | total_order_price | varchar | 64 | 0 | Y | N | 订单总价 | |
10 | receiving_address | text | 65535 | 0 | Y | N | 收货地址 | |
11 | order_status | varchar | 64 | 0 | Y | N | 订单状态 | |
12 | after_sales_reasons | text | 65535 | 0 | Y | N | 售后原因 | |
13 | pay_state | varchar | 16 | 0 | N | N | 未支付 | 支付状态 |
14 | pay_type | 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 | production_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 | contact_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 | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | retail_information_id | int | 10 | 0 | N | Y | 零售信息ID | |
2 | retail_users | int | 10 | 0 | Y | N | 0 | 零售用户 |
3 | product_batch | varchar | 64 | 0 | Y | N | 产品批次 | |
4 | product_name | varchar | 64 | 0 | Y | N | 产品名称 | |
5 | product_type | varchar | 64 | 0 | Y | N | 产品类型 | |
6 | product_price | int | 10 | 0 | Y | N | 0 | 产品价格 |
7 | product_inventory | int | 10 | 0 | Y | N | 0 | 产品库存 |
8 | product_images | varchar | 255 | 0 | Y | N | 产品图片 | |
9 | product_description | text | 65535 | 0 | Y | N | 产品描述 | |
10 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
11 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | retail_orders_id | int | 10 | 0 | N | Y | 零售订单ID | |
2 | retail_users | int | 10 | 0 | Y | N | 0 | 零售用户 |
3 | product_batch | varchar | 64 | 0 | Y | N | 产品批次 | |
4 | product_name | varchar | 64 | 0 | Y | N | 产品名称 | |
5 | product_type | varchar | 64 | 0 | Y | N | 产品类型 | |
6 | product_price | varchar | 64 | 0 | Y | N | 产品价格 | |
7 | farmer_users | int | 10 | 0 | Y | N | 0 | 农民用户 |
8 | order_quantity | int | 10 | 0 | Y | N | 0 | 下单数量 |
9 | total_order_price | varchar | 64 | 0 | Y | N | 订单总价 | |
10 | receiving_address | text | 65535 | 0 | Y | N | 收货地址 | |
11 | order_status | varchar | 64 | 0 | Y | N | 订单状态 | |
12 | after_sales_reasons | text | 65535 | 0 | Y | N | 售后原因 | |
13 | pay_state | varchar | 16 | 0 | N | N | 未支付 | 支付状态 |
14 | pay_type | 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 | retail_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 | contact_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 | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | system_announcement_id | int | 10 | 0 | N | Y | 系统公告ID | |
2 | announcement_number | varchar | 64 | 0 | Y | N | 公告编号 | |
3 | announcement_title | varchar | 64 | 0 | Y | N | 公告标题 | |
4 | announcement_date | date | 10 | 0 | Y | N | 公告日期 | |
5 | announcement_image | varchar | 255 | 0 | Y | N | 公告图片 | |
6 | announcement_content | text | 65535 | 0 | Y | N | 公告内容 | |
7 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
8 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
表upload (文件上传)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | upload_id | int | 10 | 0 | N | Y | 上传ID | |
2 | name | varchar | 64 | 0 | Y | N | 文件名 | |
3 | path | varchar | 255 | 0 | Y | N | 访问路径 | |
4 | file | varchar | 255 | 0 | Y | N | 文件路径 | |
5 | display | varchar | 255 | 0 | Y | N | 显示顺序 | |
6 | father_id | int | 10 | 0 | Y | N | 0 | 父级ID |
7 | dir | varchar | 255 | 0 | Y | N | 文件夹 | |
8 | type | varchar | 32 | 0 | Y | N | 文件类型 |
表user (用户账户:用于保存用户登录信息)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | user_id | mediumint | 8 | 0 | N | Y | 用户ID:[0,8388607]用户获取其他与用户相关的数据 | |
2 | state | smallint | 5 | 0 | N | N | 1 | 账户状态:[0,10](1可用|2异常|3已冻结|4已注销) |
3 | user_group | varchar | 32 | 0 | Y | N | 所在用户组:[0,32767]决定用户身份和权限 | |
4 | login_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 上次登录时间: |
5 | phone | varchar | 11 | 0 | Y | N | 手机号码:[0,11]用户的手机号码,用于找回密码时或登录时 | |
6 | phone_state | smallint | 5 | 0 | N | N | 0 | 手机认证:[0,1](0未认证|1审核中|2已认证) |
7 | username | varchar | 16 | 0 | N | N | 用户名:[0,16]用户登录时所用的账户名称 | |
8 | nickname | varchar | 16 | 0 | Y | N | 昵称:[0,16] | |
9 | password | varchar | 64 | 0 | N | N | 密码:[0,32]用户登录所需的密码,由6-16位数字或英文组成 | |
10 | | 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 | 更新时间: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | wholesale_information_id | int | 10 | 0 | N | Y | 批发信息ID | |
2 | wholesale_users | int | 10 | 0 | Y | N | 0 | 批发用户 |
3 | product_batch | varchar | 64 | 0 | Y | N | 产品批次 | |
4 | product_name | varchar | 64 | 0 | Y | N | 产品名称 | |
5 | product_type | varchar | 64 | 0 | Y | N | 产品类型 | |
6 | product_price | int | 10 | 0 | Y | N | 0 | 产品价格 |
7 | product_inventory | int | 10 | 0 | Y | N | 0 | 产品库存 |
8 | product_images | varchar | 255 | 0 | Y | N | 产品图片 | |
9 | product_description | text | 65535 | 0 | Y | N | 产品描述 | |
10 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
11 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | wholesale_orders_id | int | 10 | 0 | N | Y | 批发订单ID | |
2 | wholesale_users | int | 10 | 0 | Y | N | 0 | 批发用户 |
3 | product_batch | varchar | 64 | 0 | Y | N | 产品批次 | |
4 | product_name | varchar | 64 | 0 | Y | N | 产品名称 | |
5 | product_type | varchar | 64 | 0 | Y | N | 产品类型 | |
6 | product_price | varchar | 64 | 0 | Y | N | 产品价格 | |
7 | retail_users | int | 10 | 0 | Y | N | 0 | 零售用户 |
8 | order_quantity | int | 10 | 0 | Y | N | 0 | 下单数量 |
9 | total_order_price | varchar | 64 | 0 | Y | N | 订单总价 | |
10 | receiving_address | text | 65535 | 0 | Y | N | 收货地址 | |
11 | order_status | varchar | 64 | 0 | Y | N | 订单状态 | |
12 | after_sales_reasons | text | 65535 | 0 | Y | N | 售后原因 | |
13 | pay_state | varchar | 16 | 0 | N | N | 未支付 | 支付状态 |
14 | pay_type | 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 | wholesale_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 | contact_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 | 更新时间 |
5 系统实现
在此部分内容中,主要通过系统功能的运行效果图展示前面设计的最终结果。系统实现对编制人员的技术能力有较高要求,因为需要他们使用编程的方式去实现系统设计的方案。
5.1注册登录功能模块
5.1.1 用户注册界面
用户点击首页左上角“注册”按钮进入注册页面,填写个人账号+密码+姓名+头像+邮箱+身份等信息后点击“注册”,点击“注册”按钮后系统会验证两次输入的密码是否一致,验证输入的账户名和数据库表中已经注册的账户名是否重复,验证通过后即可注册成功。其用户注册界面展示如下图5-1所示。
图5-1用户注册界面图
注册关键代码如下所示。
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);
}
5.1.2 用户登录界面
用户注册成功后可以通过输入账号、密码进行登录,当用户输入完信息并点击“登录”按钮后,系统会验证输入的信息是否完整和准确,验证通过后即可完成登录,用户登录界面如下图5-2所示。
图5-2用户登录界面图
登录关键代码如下所示。
@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<>();
生产用户在“生产信息”界面可以对生产信息进行查看和管理,在生产信息管理界面点击“新增”按钮进入添加页面、填写产品名称、产品价格、产品图片、产品描述等信息即可完成生产信息的添加,还可以对生产信息进行查询、重置、删除操作。添加生产信息界面如下图5-3所示。
图5-3 添加生产信息界面图
5.2.2生产订单界面
当生产用户在“生产订单”列表可查看所有的批发用户的订单信息,点击某一订单可查看详情,并可更改订单状态或处理售后等操作,订单详情的展示页面如图5-4所示。
图5-4 订单详情界面图
5.3批发用户功能模块
批发用户在生产信息页面可查看所有的产品信息,可进行详情、查询、在线下单等操作,批发用户下单界面如下图5-5所示。
图5-5 批发用户提交订单界面图
批发用户在“批发信息”界面可以对批发信息进行查看和管理,在批发信息管理界面点击“新增”按钮进入添加页面,填写产品名称、产品价格、产品图片、产品描述等信息即可完成批发信息的添加,还可以对批发信息进行查询、重置、删除操作。添加批发信息界面如下图5-6所示。
图5-6添加批发信息界面图
零售用户在批发信息页面可查看所有的产品信息,可进行详情、查询、在线下单等操作,零售用户下单界面如下图5-9所示。
图5-9零售用户下单界面图
5.4.2批发订单界面
零售用户在批发订单列表可查看自己的所有订单,可进行查看详情、在线支付和申请售后等操作,支付界面如下图5-10所示。
图5-10 支付界面图
图5-11申请售后界面图
零售用户在“零售信息”界面可以对零售产品进行查看和管理,在零售信息管理界面点击“新增”按钮进入添加页面,填写产品名称、产品价格、产品图片、产品描述等信息即可完成零售信息的添加,还可以对零售信息进行查询、重置、删除操作。添加零售产品界面如下图5-9所示。
图5-11 添加零售产品界面
农民用户可在系统公告页面查看管理员发布的公告信息,包括公告标题、公告图片、公告内容等信息,公告列表如下图5-12所示。
图5-12 公告信息列表界面
农民用户在零售信息列表页面可通过产品名称或产品类型进行快速搜索自己需要的商品信息,可进行查看详情或在线下单操作,零售信息列表如下图5-13所示。
图5-13 零售信息列表界面
农民用户在零售订单列表可查看自己的所有订单信息,可进行查看详情、在线支付和申请售后等操作,支付界面如下图5-14所示。
图5-13 零售订单列表界面
输入账号、密码进行验证登录,当管理员输入完信息并点击“登录”按钮后,系统会验证输入的信息是否完整和准确,验证通过后即可完成登录。管理员登录界面如下图5-14所示。
图5-14管理员登录界面图
管理员可以发布、编辑、删除网站公告内容,包括公告日期、公告图片、公告内容等,及时向用户传达重要信息,系统公告管理界面如下图5-15所示。
图5-15系统公告管理界面图
管理人员在“系统用户”这一菜单中可以对生产用户、批发用户、零售用户、农民用户以及管理员进行管理。界面如下图5-16所示。
图5-16系统用户管理界面图
系统用户管理关键代码如下所示。
@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);
}
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){
StringBuffer sql = new StringBuffer("INSERT INTO ");
sql.append("`").append(table).append("`").append(" (");
for (Map.Entry<String,Object> entry:body.entrySet()){
sql.append("`"+humpToLine(entry.getKey())+"`").append(",");
}
sql.deleteCharAt(sql.length()-1);
sql.append(") VALUES (");
for (Map.Entry<String,Object> entry:body.entrySet()){
Object value = entry.getValue();
if (value instanceof String){
sql.append("'").append(entry.getValue()).append("'").append(",");
}else {
sql.append(entry.getValue()).append(",");
}
}
sql.deleteCharAt(sql.length() - 1);
sql.append(")");
log.info("[{}] - 插入操作:{}",table,sql);
Query query = runCountSql(sql.toString());
query.executeUpdate();
}
5.2.4 商城管理
管理人员在“商城管理”这一菜单中可以对商品信息进行查询和添加分类管理。
在分类添加页面填写分类名称完成分类列表的信息添加,还可以进行查询、重置、删除操作。界面如下图5-15所示。
图5-15分类列表管理界面图
6系统测试
这部分内容主要是把前期编码完成的系统,当成是计算机系统的一部分,并结合一些数据,计算机硬件和支持的软件进行集成测试和确认测试。之所以要进行最后的测试步骤,原因在于检查制作的系统与需求说明书的比较中,存在的差异问题。进一步确认制作的系统在功能与性能上跟需求说明书当中的要求相符。
6.1 系统测试的类型
检测系统是否合格,需要用到很多的测试类型。接下来就对这部分内容进行描述。
功能测试:这是系统测试中,首先进行的测试内容,其属于黑盒测试。主要检验制作的系统与需求说明文档的相符程度,还有它们之间存在的差异问题。
性能测试:主要测试制作的系统,在同时面对很多的用户请求时,该系统的应对能力。同时也是检查制作的系统跟事先预定的系统性能存在的差距问题。这样的方法通常在实时系统中,或者是嵌入式系统中运用得比较多。
容量测试:这种方法针对数据。检查正常运行的系统对数据处理的容量值。
安全性测试:这种方法常用于检验系统中设置的安全保护机制对来自非法用户的攻击时是否有效。而检测系统中的信息保护机制就需要使用常见安全测试中的保护测试来验证。
健壮性测试:这种测试还有一个别称是容错测试,通常运用故障插入法来检测系统的容错能力,看系统是否可以忽略故障保持继续运行,或者是检测系统应对故障时的自动恢复能力。
兼容性测试:面对计算机的各种软硬件环境,检测本系统是否可以兼容。
易用性测试:这种方法主要是面向用户,检测用户是否很容易理解和使用系统。
6.2 功能测试
农产品供应链管理系统在经历最后的测试环节,需要检验本系统的功能安全性,功能适用性等内容,最终得出测试结论。
表6.1 功能测试数据表
符合要求 | |
符合要求 | |
符合要求 | |
符合要求 | |
符合要求 |
6.3 可用性测试
通常来说,一个布局合理,显示的内容无错别字,并具备合理正常的操作逻辑的系统往往很受欢迎,而且可以提升访问者的使用时间以及访问率。
表6.2 可用性测试数据表
测试内容 | 测试结果 |
合理 | |
合理 | |
能 | |
无 | |
检查系统功能有无友好性 | 有 |
能 | |
无 | |
检查系统有无提供帮助信息 | 有 |
6.4 测试结果分析
农产品供应链管理系统经过了编码阶段的单元测试,和最后的系统整体测试等测试后,对于用户要求的功能,本系统都进行了实现,各个模块都运行正常。在面对一些故障性问题时,本系统也有相应的应对办法,并且本系统可以保持24小时正常运转。因此,农产品供应链管理系统可以交付用户使用。
结 论
2024年的今天,计算机技术已经相当成熟。它的发展推动了许多行业改头换面,计算机的出现使人类社会有了进一步降低人力物力和资源的方法。
本文利用SSM框架和MySQL数据库技术,完成了农产品供应链管理系统。经调试结果显示,本系统基本可以满足一个农产品供应链管理系统的业务需要。系统界面简洁而有美感,易操作,做出了自己的特色,然而因为时间仓促再加上缺乏系统开发经验和仅依靠少数问卷调查方式,因此本系统还存在不少缺陷、不足,比如:
1. 数据输入的格式并没有全部检验,所以很难保证数据的准确,可能有一些不符合规则的数据也可以通过检验。
2. 系统功能还不够完善,无法提供丰富多彩的在线功能。
本系统还存在一些漏洞没有解决,在现实应用情境中很难保证完全不出错,但相信通过再次完善,可以调试出真正符合实际的农产品供应链管理系统。
[1]袁琳琳. 计算机软件Java编程特点及技术分析[J]. 数字通信世界, 2023, (12): 87-89.
[2]毛霖, 张帆, 陈海军, 齐佰剑, 杨庆庆, 黄德民. 农产品供应链运输管理系统及方法[P]. 江苏省: CN117236825A, 2023-12-15.
[3]马庆. 计算机软件开发中JAVA编程语言的应用[J]. 山西电子技术, 2023, (06): 84-86+98.
[4]徐正超, 王义斐, 谭煜凯, 朱立佳, 李强. 基于HTML的实验预约管理系统设计与实现[J]. 科技与创新, 2023, (22): 146-148.
[5]张国芳. Java编程语言在计算机软件开发中的应用方向分析[J]. 信息记录材料, 2023, 24 (11): 138-141.
[6]Zhang Xiao, Yu Ali, Wang Xin, Zhang Xue. Sports Work Strategy of College Counselors Based on MySQL Database Big Data Analysis[J]. International Journal of Information Technology and Web Engineering (IJITWE), 2023, 18 (1): 1-14.
[7]崔于琦. 农产品供应链风险管理问题研究[J]. 现代商业, 2023, (15): 15-18.
[8]熊群毓. 大数据时代MySQL数据库的应用分析[J]. 信息与电脑(理论版), 2023, 35 (14): 209-212.
[9]Gopi Karthik, Mazumder Debashish, Crawford Jagoda, Gadd Patricia, Tadros Carol V, Atanacio Armand, Saintilan Neil, Sammut Jesmond. Developing a MySQL Database for the Provenance of Black Tiger Prawns (Penaeus monodon).[J]. Foods (Basel, Switzerland), 2023, 12 (14):
[10]李洋, 刘婷. MySQL数据库安全加固技术的研究[J]. 科技与创新, 2023, (13): 120-122.
[11]李艳杰. 基于MySQL数据库的数据安全应用设计[J]. 现代信息科技, 2023, 7 (12): 151-154.
[12]刘立栋, 丁康健, 樊雪, 董庆杰. 基于区块链技术的有机农产品供应链管理系统设计[J]. 信息与电脑(理论版), 2023, 35 (12): 140-142.
[13]Mulla Nikahat, Gharpure Prachi. Leveraging well-formedness and cognitive level classifiers for automatic question generation on Java technical passages using T5 transformer[J]. International Journal of Information Technology, 2023, 15 (4): 1961-1973.
[14]晁孟华, 梁金凤. 农产品供应链系统数字化方案构建策略研究——以广东覃斗芒果产业为例[J]. 全国流通经济, 2022, (31): 4-7.
[15]张俐华. 农产品供应链智能物流配送管理系统[P]. 江西省: CN215555225U, 2022-01-18.
[16]刘欣, 刘卫忠, 黄思韵. 一种应用物联网技术的农产品供应链管理系统[P]. 广东省: CN212748792U, 2021-03-19.
[17]李晓琳. 基于物联网农产品供应链信息管理系统的构建[J]. 企业科技与发展, 2020, (11): 78-79.
[18]王丽红. 麦咨达实现农产品供应链全过程质量管理的经验[J]. 天津农业科学, 2019, 23 (05): 61-64+77.
[19]朱巧环, 杨慧鹏. 基于电子商务平台的农产品供应链模式[J]. 现代企业, 2019, (03): 54-55.
致 谢
伴随着毕设项目的制作完成,也就意味着我们即将离开校园。回想几年的大学时光,不由得想起身边常伴的同学,授课的老师,还有毕设指导的老师们。
大学这几年,身边的同学为我提供了很多的帮助,不管是生活上,还是学习上,每次遇到问题,这些同学们都会耐心解答,有时为了避免我再次犯错,他们也会时不时提醒我。本次毕设制作期间,这些老同学也是互相分享开发经验,还有文档编写的技巧,从开题报告,还有任务书以及最后的论文等文档上,大家都是互相提出建议,互相参考一些编写经验和技巧。如此,我们才会进展得比较顺利。此刻,真心感谢这些老同学!
唯一不能忘记的是导师,平均每个导师都带了很多个毕业生,所以能够想象他们非常忙,因为一到毕业季,他们需要指导学生们毕业,还需要正常授课。作为本届毕业生,我也能够体会导师的辛苦和不容易。毕设制作的环节有很多,但是我的导师在进行的每个环节都严格要求我认真努力对待本项目,也对我编程技术上提出了很多至关重要的建议,还对一些比较细微但是也比较关键的部分向我进行了多次强调,让我少走弯路,可以如期实现本系统。此刻,真心感谢导师!
校园里的授课老师不仅有本专业的老师,也有其他专业的老师们,他们都教过我们课程,向我们传授知识,有了这些知识积累,我在本次毕设制作中,才知道有些问题该如何运用知识处理,此刻,感谢那些授课老师。
最后时刻,我要感谢校园,祝愿校园更加强大!
免费领取项目源码,请关注❥点赞收藏并私信博主,谢谢~