asp.net网站建设ppt,wordpress 修改文章id,wordpress并发亿万,大连网站 设计公司SSM线上知识竞赛系统 摘 要 科技进步的飞速发展引起人们日常生活的巨大变化#xff0c;电子信息技术的飞速发展使得电子信息技术的各个领域的应用水平得到普及和应用。信息时代的到来已成为不可阻挡的时尚潮流#xff0c;人类发展的历史正进入一个新时代。在现实运用中#… SSM线上知识竞赛系统 摘 要 科技进步的飞速发展引起人们日常生活的巨大变化电子信息技术的飞速发展使得电子信息技术的各个领域的应用水平得到普及和应用。信息时代的到来已成为不可阻挡的时尚潮流人类发展的历史正进入一个新时代。在现实运用中应用软件的工作规则和开发步骤采用Java技术建设线上知识竞赛系统。 本设计主要实现集人性化、高效率、便捷等优点于一身的线上知识竞赛系统完成主页个人资料公共管理轮播图公告信息用户管理管理员普通用户信息管理竞赛资讯资讯分类竞赛答题竞赛信息竞赛报名竞赛排行等功能模块。系统通过浏览器与服务器进行通信实现数据的交互与变更。本系统通过科学的管理方式、便捷的服务提高了工作效率减少了数据存储上的错误和遗漏。线上知识竞赛系统使用Java语言采用基于 MVC模式的SSM技术进行开发使用 Eclipse 2017 CI 10 编译器编写数据方面主要采用的是微软的MySQL数据库来作为数据存储媒介配合前台HTMLCSS 技术完成系统的开发。 关键词线上知识竞赛SSM框架Java语言MySQL数据库 SSM Online Knowledge Competition System Abstract The rapid development of technology has caused tremendous changes in peoples daily lives, and the rapid development of electronic information technology has popularized and applied the application level of electronic information technology in various fields. The arrival of the information age has become an unstoppable fashion trend, and the history of human development is entering a new era. In practical applications, the working rules and development steps of application software are constructed using Java technology to build an online knowledge competition system. This design mainly implements an online knowledge competition system that combines the advantages of humanization, efficiency, and convenience. It completes functional modules such as homepage, personal information, public management (broadcast maps, announcement information), user management (administrators, ordinary users), information management (competition information, information classification, competition answers), competition information, competition registration, competition ranking, etc. The system communicates with the server through a browser to achieve data interaction and changes. This system improves work efficiency and reduces errors and omissions in data storage through scientific management and convenient services. The online knowledge competition system is developed using Java language and SSM technology based on MVC mode. It is written using the Eclipse 2017 CI 10 compiler. The data is mainly stored in Microsofts MySQL database, and the system is developed in conjunction with front-end HTMLCSS technology. Key words: online knowledge competition; SSM framework; Java language; MySQL database 目 录 摘 要 Abstract 第1章 绪论 1.1 研究背景与意义 1.2 开发现状 1.3 本文的组织结构 第2章 相关技术介绍 2.1 开发技术 2.2 SSM框架介绍 2.3 MVVM模式 2.4 B/S结构 2.5 MySQL数据库 2.6 Vue.js 主要功能 第3章 系统分析 3.1 可行性分析 3.1.1 技术可行性分析 3.1.2 经济可行性分析 3.1.3 操作可行性分析 3.2 功能需求分析 3.3 非功能需求分析 3.4 数据流程分析 第4章 系统设计 4.1 系统架构设计 4.2 系统功能结构 4.3 功能模块设计 4.4 表单字段校验处理设计 4.5 系统维护设计 4.6 数据库设计 4.6.1 概念模型 4.6.2 数据表 第5章 系统实现 5.1 登录模块的实现 5.2 首页模块 5.3 普通用户功能模块 5.4 管理员功能模块 第6章 系统测试 6.1 测试目的 6.2 测试过程 6.3 测试结果 第7章 总结与展望 参考文献 致谢 绪论 研究背景与意义 在20世纪末期国家就提出了教育要面向四个现代化同时也提出了要大力发展教育手段和教育方式的信息化建设。在这样的背景和需求下基于当今的互联网技术和计算机信息技术的线上知识竞赛系统就应运而生了。人们急切地需要在在线竞赛中利用现代网络技术达到工作量减少并且提高举办单位工作效率的目的。同时与传统的竞赛形式相比竞赛的质量也更能得以保证从而使得竞赛变得更为客观公正。 线上知识竞赛系统的实现让竞赛不再局限于只能在教室中进行它利用网络的优势使得竞赛不再像以前那么复杂考生也不再需要定时定点而是随时随地就能参与竞赛。线上知识竞赛系统具有传统的竞赛模式无法媲美的准确、科学、公平、方便等优点于是对线上知识竞赛系统的研究和建设也就在这样的环境中逐渐发展了起来。 开发现状 在越来越重视知识的当今社会各个国家都加大了在新一代培育上的投入都希望在以后的社会发展中走在互联网的前列从而在信息的飞速发展中占据一个有力的地位正是这个原因各地政府依托于互联网来实行教育教学并把此作为其民族发展的动力之源。 在外国澳大利亚在早期就开始投资建设“澳大利亚教育网”这个网络不但包含了澳大利亚全部的高校还要联通本国境内的每一所中小学。另外美国政府提出要到二十一世纪初让本国家所有学校和图书馆都搭载上互联网的快车让国内不论是哪个阶段的学生都可以享受到“21世纪教师”的网络服务因此提出了“教育技术规划Educational Technology Initiative”。到了1995年末国外一些教育机构开始开发自己的网上教育平台最早的有美国的NTU、英国的OPEN COLLEGE等这些都是那个时候实施互联网教育的典范。随着教育搭载上互联网的高速公路在线竞赛作为远程教育不可分割的一项随着互联网的大潮也如雨后春笋般迅速发展起来人们的选课和竞赛都在互联网上进行特别是互联网业务的普及、低成本的在线竞赛从技术和经济条件上已经日趋成熟。 在国内很大一部分的学校的教学教辅工作还普遍停留在传统的方式上例如采用传统的纸质竞赛测试方法但是传统的竞赛每次都需要人为的出卷、组织竞赛、批改试卷并且做出许多试卷分析和成绩评估作为老师一次竞赛的实施给他们带来了许多的麻烦并且随着教育现代化竞赛类型的增加和竞赛要求的更加严格教师的工作也会变得越来越繁重。而现在人们普遍认为的网络教育也是停留在网上报名授课和成绩查询没有形成相应的规模而国外网上竞赛已经变得非常普及所以传统竞赛方式终将面临变革线上知识竞赛系统应运而生。 本文的组织结构 第一章是绪论本文章的开头部分对本题目的研究背景和研究意义等一些做文字性的描述。 第二章研究了线上知识竞赛系统的所采用的开发技术和开发工具。 第三章是系统分析部分包括系统总体需求描述、功能性角度分析系统需求、非功能性等各个方面分析系统是否可以实现。 第四章是系统设计部分本文章的重要部分提供了系统架构的详细设计和一些主要功能模块的设计说明。 第五章是系统的具体实现介绍系统的各个模块的具体实现。 第六章在前几章的基础上对系统进行测试和运行。 最后对系统进行了认真的总结以此对未来有一个新的展望。 相关技术介绍 开发技术 本系统前端部分基于MVVM模式进行开发采用B/S模式后端部分基于Java的SSM框架进行开发。 前端部分前端框架采用了比较流行的渐进式JavaScript框架Vue.js。使用Vue-Router和Vuex实现动态路由和全局状态管理,Ajax实现前后端通信Element UI组件库使页面快速成型项目前端通过栅格布局实现响应式可适应PC端、平板端、手机端等不同屏幕大小尺寸的完美布局展示。 后端部分采用SSM作为开发框架同时集成MyBatis、Redis等相关技术。 SSM框架介绍 SSMSpringSpringMVCMyBatis框架集由Spring、MyBatis两个开源框架整合而成SpringMVC是Spring中的部分内容。常作为数据源较简单的web项目的框架。 Spring Spring就像是整个项目中装配bean的大工厂在配置文件中可以指定使用特定的参数去调用实体类的构造方法来实例化对象。也可以称之为项目中的粘合剂。 Spring的核心思想是IoC控制反转即不再需要程序员去显式地new一个对象而是让Spring框架帮你来完成这一切。 SpringMVC SpringMVC在项目中拦截用户请求它的核心Servlet即DispatcherServlet承担中介或是前台这样的职责将用户请求通过HandlerMapping去匹配ControllerController就是具体对应请求所执行的操作。SpringMVC相当于SSH框架中struts。 Mybatis mybatis是对jdbc的封装它让数据库底层操作变的透明。mybatis的操作都是围绕一个sqlSessionFactory实例展开的。mybatis通过配置文件关联到各实体类的Mapper文件Mapper文件中配置了每个类对数据库所需进行的sql语句映射。在每次与数据库交互时通过sqlSessionFactory拿到一个sqlSession再执行sql命令。 页面发送请求给控制器控制器调用业务层处理逻辑逻辑层向持久层发送请求持久层与数据库交互后将结果返回给业务层业务层将处理逻辑发送给控制器控制器再调用视图展现数据。 MVVM模式 MVVM是Model-View-ViewModel的简写。它本质上就是MVC 的改进版。MVVM 就是将其中的View 的状态和行为抽象化让我们将视图 UI 和业务逻辑分开。当然这些事 ViewModel 已经帮我们做了它可以取出 Model 的数据同时帮忙处理 View 中由于需要展示内容而涉及的业务逻辑。微软的WPF带来了新的技术体验如Silverlight、音频、视频、3D、动画……这导致了软件UI层更加细节化、可定制化。同时在技术层面WPF也带来了 诸如Binding、Dependency Property、Routed Events、Command、DataTemplate、ControlTemplate等新特性。MVVMModel-View-ViewModel框架的由来便是MVPModel-View-Presenter模式与WPF结合的应用方式时发展演变过来的一种新型架构框架。它立足于原有MVP框架并且把WPF的新特性糅合进去以应对用户日益复杂的需求变化。 B/S结构 B/SBrowser/Server比前身架构更为省事的架构。它借助Web server完成数据的传递交流。只需要下载浏览器作为用户端那么工作就达到“瘦身”效果 不需要考虑不停装软件的问题[9]。 MySQL数据库 Mysql的语言是非结构化的用户可以在数据上进行工作。MySQL因为其速度、可靠性和适应性而备受关注。大多数人都认为在不需要事务化处理的情况下MySQL是管理内容最好的选择。并且因为Mysql的语言和结构比较简单但是功能和存储信息量很强大所以得到了普遍的应用。 Mysql数据库在编程过程中的作用是很广泛的为用户进行数据查询带来了方便。Mysql数据库的应用因其灵活性强功能强大所以在实现某功能时只需要一小段代码而不像其他程序需要编写大段代码。总体来说Mysql数据库的语言相对要简洁很多。 数据流程分析主要就是数据存储的储藏室它是在计算机上进行的而不是现实中的储藏室。数据的存放是按固定格式而不是无序的其定义就是长期有固定格式可以共享的存储在计算机存储器上。数据库管理主要是数据存储、修改和增加以及数据表的建立。为了保证系统数据的正常运行一些有能力的处理者可以进行管理而不需要专业的人来处理。数据表的建立可以对数据表中的数据进行调整数据的重新组合及重新构造保证数据的安全性。介于数据库的功能强大等特点本系统的开发主要应用了Mysql进行对数据的管理。 Vue.js 主要功能 Vue.js是一套构建用户界面的渐进式框架。与其他重量级框架不同的是Vue采用自底向上增量开发的设计。Vue 的核心库只关注视图层并且非常容易学习非常容易与其它库或已有项目整合。另一方面Vue 完全有能力驱动采用单文件组件和Vue生态系统支持的库开发的复杂单页应用。 Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。 Vue.js 自身不是一个全能框架——它只聚焦于视图层。因此它非常容易学习非常容易与其它库或已有项目整合。另一方面在与相关工具和支持库一起使用时Vue.js 也能驱动复杂的单页应用。 系统分析 可行性分析 本次设计基于B/S 模式下运用Java技术采用的是MySQL数据库和Eclipse实现总体的可行性共分为以下三个方面。 技术可行性分析 所谓的技术可行性就是在限定时间前期拟定的功能能否被满足。在开发设计上是否会遇上解决不了的问题。做完的项目能否被很好地应用如果存在缺点在后期的维护上是否存在很大的难度。在对这个系统评估后认定已存在的技术能达成目标。用Java技术来实现动态的页面嵌入低依赖性的设计模式灵活的数据库配合稳定的服务器整个系统的运行效率大大提升。由此可见在技术层面达成目标不是非非之想。 经济可行性分析 在项目上使用的工具大部分都是是当下流行开源免费的所以在开发前期开发时用于项目的经费将会大大降低不会让开发该软件在项目启动期受到经费的影响所以经济上还是可行的。尽量用最少的花费去满足用户的需求。省下经费用于人工费以及设备费用。将在无纸化高效率的道路上越走越远。 操作可行性分析 本系统实现功能的操作很简单普通电脑的常见配置就可以运行本软件并且只要粗通电脑使用的基本常识就可以流畅的使用本软件。电脑具备连接互联网的能力并且可以正常访问系统并不需要操作者有什么高超的能力只需了解业务流程并且按照专业知识进行正确操作即可所以线上知识竞赛系统具备操作可行性。 功能需求分析 在系统开发设计前应该对功能做初步设想清楚这个管理系统有什么板块每个板块有什么功能整体的设计是否满足使用者的需求接着对所开发的系统功能进行的详细分析总结从而设计出完整的系统并将其实现。用户和开发人员的交流分析使其达到最佳理解程度使系统功能达到最佳。 用户用例图如下所示。 图3-1 用户用例图 管理员用例图如下所示。 图3-2 管理员用例图 线上知识竞赛系统在对需求做解析后整个系统主要分为两个部分管理员、普通用户模块每个模块下的分支功能不一样。对功能做出如下说明 注册模块用户可自行注册也可由管理员添加账户用户有密码修改等功能登录模块管理员及用户同构输入用户名密码完成图片验证方可登录系统竞赛信息管理员设发布竞赛信息设置竞赛时间用户在规定时间内可答题竞赛答题管理员设计竞赛题库用户答题提交答卷并等待管理员评分竞赛排行管理员完成评分后发布成绩排行用户查询确认。用户管理管理员维护管理用户信息还可以进行重置、添加、删除等操作。 非功能需求分析 系统非功能需求有非常多比如性能需求、可承载最大用户数、稳定性、易用性需求等。本系统分析时考虑到易用性需求因为系统是给人使用的所以必须充分从用户的角度出发考虑用户体验使系统易理解易上手易操作。 数据流程分析 一层数据流程图包括了登录、用户功能和检索维护等模块在登录模块使用到的数据存储有用户账户文档用户功能模块需要的存储是用户各功能模块数据文档检索维护是使用以上这些数据文档通过关键词进行检索。 系统的一层数据流图如下图所示。 图3-2系统数据流图一层 二层数据流程是对一层数据流层图中填写登录信息、用户功能的细化。即用户管理管理员普通用户信息管理竞赛资讯资讯分类竞赛答题竞赛信息竞赛报名竞赛排行等操作。 系统的二层数据流图如下图所示。 图3-4系统数据流图二层 系统设计 系统架构设计 目前B/S体系的系统主要的数据访问方式是通过浏览器页面用户可以进入系统系统可以自动对用户向服务器发送的请求进行处理处理请求是在系统后台中进行的用户在浏览器页面上进行相应操作就能够看到服务端传递的处理结果。线上知识竞赛系统主要分为视图-模型-控制三层架构设计。在视图层中主要是操作在服务器端向客户端反馈并显示的数据在模型层中主要处理相关的业务逻辑、数据整合等最后的控制层它介于视图和模型之间主要是调整两层之间的关系最终落实数据的传递。 系统架构图如下图所示。 图4-1系统架构图 系统功能结构 系统设计的目的是分析系统包括的所有功能结构为开发人员设计开发和实现系统做好准备工作。经过前期的需求调查、分析和整理之后确定的总体需求主要包括多个模块分别是主页个人资料公共管理轮播图公告信息用户管理管理员普通用户信息管理竞赛资讯资讯分类竞赛答题竞赛信息竞赛报名竞赛排行等。系统整体角色分为两个部分一是普通用户、二是管理员。权限分布也是很明显用户是在除去浏览信息之外还具有查询和管理自己账户信息竞赛答题公告消息竞赛资讯竞赛信息竞赛报名竞赛排行等权限管理员是最高权限拥有者。 系统功能结构图如下图所示。 图4-2系统功能结构图 功能模块设计 用户管理模块 该模块是为所有用户登录设计的如普通用户登录后只能进行自己的普通功能操作(如个人信息修改管理员能对整个系统的数据进行管理主要是用户的登录权限以及用户登录后在系统里的操作权限。 竞赛信息管理模块 管理员维护竞赛信息关系为一对多根据编号来将工作数据传入到预定数据中然后生成竞赛信息列表查看历史竞赛信息列表可以进行数据销毁。 竞赛答题管理模块 管理员设计竞赛题库生产题库表用户答题生成答卷信息表提交答卷并等待管理员评分。 竞赛排行管理模块 管理员完成评分后发布成绩排行用户查询确认。 表单字段校验处理设计 1.出错信息类型 出错信息类型包括 A 未输入必填项 B 应输入合法字符或数字却输入非法字符或数字 C 对空数据表进行更改或删除操作 D 向要求唯一值的关键字段添加重复值。 2.出错处理对策 对于错误A系统要求用户输入非空值。 对于错误B系统要求用户输入合法字符。 对于错误C系统提示数据表无记录可更改或删除。 对于错误D系统要求用户输入非重复值。 系统维护设计 线上知识竞赛系统是个现代化的高度集成的综合信息系统系统主要服务对象为用户最大化在页面中提供多的信息因此在系统维护上数据量较大整体的维护设计如下 1代码的维护部署在云服务器上或本地服务器通过SVN或FTP保持版本更新迭代。 2功能增加功能升级在必要的前提下。 3数据维护根据安全性等需求定期对数据库进行人工备份。 数据库设计 概念模型 对于一个要开发的系统来说E-R图可以让别人能更快更轻松的了解此系统的事务及它们之间的关系。根据系统分析阶段所得出的结论确定了在线上知识竞赛系统中存在着多个实体分别是用户、管理员、竞赛信息、题库、答卷、成绩排行信息等。 系统总体ER图如下图所示。 图4-4系统总体ER图 数据表 数据库逻辑结构就是将E-R图在数据库中用具体的字段进行描述。用字段和数据类型描述来使对象特征实体化最后形成具有一定逻辑关系的数据库表结构。线上知识竞赛系统所需要的部分数据结构表如下表所示。 表access_token (登陆访问时长) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 token_id int 10 0 N Y 临时访问牌ID 2 token varchar 64 0 Y N 临时访问牌 3 info text 65535 0 Y N 4 maxage int 10 0 N N 2 最大寿命默认2小时 5 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 6 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 7 user_id int 10 0 N N 0 用户编号: 表article (文章用于内容管理系统的文章) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 article_id mediumint 8 0 N Y 文章id[0,8388607] 2 title varchar 125 0 N Y 标题[0,125]用于文章和html的title标签中 3 type varchar 64 0 N N 0 文章分类[0,1000]用来搜索指定类型的文章 4 hits int 10 0 N N 0 点击数[0,1000000000]访问这篇文章的人次 5 praise_len int 10 0 N N 0 点赞数 6 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 7 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 8 source varchar 255 0 Y N 来源[0,255]文章的出处 9 url varchar 255 0 Y N 来源地址[0,255]用于跳转到发布该文章的网站 10 tag varchar 255 0 Y N 标签[0,255]用于标注文章所属相关内容多个标签用空格隔开 11 content longtext 2147483647 0 Y N 正文文章的主体内容 12 img varchar 255 0 Y N 封面图 13 description text 65535 0 Y N 文章描述 表article_type (文章分类) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 type_id smallint 5 0 N Y 分类ID[0,10000] 2 display smallint 5 0 N N 100 显示顺序[0,1000]决定分类显示的先后顺序 3 name varchar 16 0 N N 分类名称[2,16] 4 father_id smallint 5 0 N N 0 上级分类ID[0,32767] 5 description varchar 255 0 Y N 描述[0,255]描述该分类的作用 6 icon text 65535 0 Y N 分类图标 7 url varchar 255 0 Y N 外链地址[0,255]如果该分类是跳转到其他网站的情况下就在该URL上设置 8 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 9 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表auth (用户权限管理) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 auth_id int 10 0 N Y 授权ID 2 user_group varchar 64 0 Y N 用户组 3 mod_name varchar 64 0 Y N 模块名 4 table_name varchar 64 0 Y N 表名 5 page_title varchar 255 0 Y N 页面标题 6 path varchar 255 0 Y N 路由路径 7 position varchar 32 0 Y N 位置 8 mode varchar 32 0 N N _blank 跳转方式 9 add tinyint 3 0 N N 1 是否可增加 10 del tinyint 3 0 N N 1 是否可删除 11 set tinyint 3 0 N N 1 是否可修改 12 get tinyint 3 0 N N 1 是否可查看 13 field_add text 65535 0 Y N 添加字段 14 field_set text 65535 0 Y N 修改字段 15 field_get text 65535 0 Y N 查询字段 16 table_nav_name varchar 500 0 Y N 跨表导航名称 17 table_nav varchar 500 0 Y N 跨表导航 18 option text 65535 0 Y N 配置 19 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 20 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表collect (收藏) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 collect_id int 10 0 N Y 收藏ID 2 user_id int 10 0 N N 0 收藏人ID 3 source_table varchar 255 0 Y N 来源表 4 source_field varchar 255 0 Y N 来源字段 5 source_id int 10 0 N N 0 来源ID 6 title varchar 255 0 Y N 标题 7 img varchar 255 0 Y N 封面 8 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 9 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表comment (评论) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 comment_id int 10 0 N Y 评论ID 2 user_id int 10 0 N N 0 评论人ID 3 reply_to_id int 10 0 N N 0 回复评论ID空为0 4 content longtext 2147483647 0 Y N 内容 5 nickname varchar 255 0 Y N 昵称 6 avatar varchar 255 0 Y N 头像地址[0,255] 7 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 8 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 9 source_table varchar 255 0 Y N 来源表 10 source_field varchar 255 0 Y N 来源字段 11 source_id int 10 0 N N 0 来源ID 表competition_information (竞赛信息) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 competition_information_id int 10 0 N Y 竞赛信息ID 2 competition_name varchar 64 0 Y N 竞赛名称 3 competition_type varchar 64 0 Y N 竞赛类型 4 competition_time datetime 19 0 Y N 竞赛时间 5 answer_duration varchar 64 0 Y N 答题时长 6 competition_requirements varchar 64 0 Y N 竞赛要求 7 competition_description text 65535 0 Y N 竞赛描述 8 competition_cover varchar 255 0 Y N 竞赛封面 9 competition_introduction longtext 2147483647 0 Y N 竞赛简介 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 更新时间 表competition_ranking (竞赛排行) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 competition_ranking_id int 10 0 N Y 竞赛排行ID 2 competition_name varchar 64 0 Y N 竞赛名称 3 competition_type varchar 64 0 Y N 竞赛类型 4 competition_time datetime 19 0 Y N 竞赛时间 5 answer_duration varchar 64 0 Y N 答题时长 6 registered_users int 10 0 Y N 0 报名用户 7 user_name varchar 64 0 Y N 用户姓名 8 competition_ranking int 10 0 Y N 0 竞赛排行 9 competition_results int 10 0 Y 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 更新时间 表competition_registration (竞赛报名) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 competition_registration_id int 10 0 N Y 竞赛报名ID 2 competition_name varchar 64 0 Y N 竞赛名称 3 competition_type varchar 64 0 Y N 竞赛类型 4 competition_time datetime 19 0 Y N 竞赛时间 5 answer_duration varchar 64 0 Y N 答题时长 6 registered_users int 10 0 Y N 0 报名用户 7 user_name varchar 64 0 Y N 用户姓名 8 registration_time datetime 19 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 更新时间 表exam (考试) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 exam_id mediumint 8 0 N Y 考试id 2 name varchar 32 0 N N 考试名称[2,32] 3 duration int 10 0 Y N 答题时长 4 score double 9 2 Y N 总分 5 status varchar 10 0 Y N 状态启用、禁用 6 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 7 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表exam_question (试题) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 exam_question_id mediumint 8 0 N Y 2 type varchar 20 0 Y N 类型 3 title varchar 255 0 Y N 题目 4 question_item varchar 500 0 Y N 选项 5 answer varchar 500 0 Y N 参考答案 6 score double 9 2 Y N 总分 7 question_order int 10 0 Y N 排序 8 exam_id mediumint 7 0 Y N 所属试卷 9 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 10 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表hits (用户点击) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 hits_id int 10 0 N Y 点赞ID 2 user_id int 10 0 N N 0 点赞人 3 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 4 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 5 source_table varchar 255 0 Y N 来源表 6 source_field varchar 255 0 Y N 来源字段 7 source_id int 10 0 N N 0 来源ID 表notice (公告) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 notice_id mediumint 8 0 N Y 公告id 2 title varchar 125 0 N N 标题 3 content longtext 2147483647 0 Y N 正文 4 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 5 update_time timestamp 19 0 N N CURRENT_TIMESTAMP 更新时间 表ordinary_users (普通用户) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 ordinary_users_id int 10 0 N Y 普通用户ID 2 user_name varchar 64 0 Y N 用户姓名 3 user_gender varchar 64 0 Y N 用户性别 4 user_age 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 更新时间 表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已取消 表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 更新时间 表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_answer (用户答题) 编号 名称 数据类型 长度 小数位 允许空值 主键 默认值 说明 1 user_answer_id mediumint 8 0 N Y 2 user_id mediumint 7 0 N N 用户ID[0,8388607]用户获取其他与用户相关的数据 3 exam_id mediumint 7 0 N N 0 考试id 4 score double 9 2 Y N 0.00 分数 5 answers text 65535 0 Y N 答案 6 score_detail text 65535 0 Y N 评分详情 7 objective_score double 9 2 Y N 0.00 客观题得分 8 subjective_score double 9 2 Y N 0.00 主观题得分 9 score_state tinyint 4 0 Y N 0 评分状态 10 nickname varchar 255 0 Y N 提交人 11 create_time timestamp 19 0 N N CURRENT_TIMESTAMP 创建时间 12 update_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 更新时间 系统实现 登录模块的实现 系统的登录窗口是用户的入口用户只有在登录成功后才可以进入访问。通过在登录提交表单后台处理判断是否为合法用户进行页面跳转进入系统中去。 登录合法性判断过程用户输入账号和密码后系统首先确定输入输入数据合法性然后发送登录请求调用src下的mainctrl类的dopost方法来验证。 用户登录模块的IPO如下所示 输入用户名和密码。 处理 1检测用户输入的账号、密码是否正确及在数据库已对应存在。 2从数据库中提取记录并储存在本地的session中timeout默认30min。 3根据用户名将其显示在系统首页上。 输出是否成功的信息。 登录流程图如下所示。 图5-1登录流程图 系统登录界面如下所示。 图5-2系统登录界面 用户登录的逻辑代码如下。 /** * 登录 * param data * param httpServletRequest * return */ PostMapping(login) public MapString, Object login(RequestBody MapString, 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 QueryWrapperUser(); MapString, 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); MapString, 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 (resnull){ 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(MapString,String query,MapString,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) { ListMapString,Object mapList baseMapper.selectBaseList(select); ListE list new ArrayList(); for (MapString,Object map:mapList) { list.add(JSON.parseObject(JSON.toJSONString(map),eClass)); } return list; } 首页模块 系统呈现出一种简洁大方的首页界面简约、鳞次栉比用户能轻车熟路的使用。出于对系统使用群体广泛的顾虑应有良好性能的后台。 如下图所示为系统的首页界面。 图5-3系统首页界面 其中载入前台页面的主要代码如下。 td% include fileqttop.jsp%/td td% include fileqtleft.jsp%/td td% include fileqtdown.jsp%/td 普通用户功能模块 竞赛信息用户在此页面可以通过关键字搜索竞赛信息可以查看竞赛名称类型时间答题时长要求等信息。可以进行报名操作。如下图所示。 图5-4竞赛信息列表 图5-5竞赛信息详情界面 图5-6竞赛报名界面 竞赛答题用户在此页面可以通过名称搜索竞赛考卷并进行答题操作。如下图所示。 图5-7竞赛答题列表 图5-8竞赛答题界面 竞赛排行管理员评分结束后用户在后台页面可以查看竞赛成绩与排名也可在前台查看如下图所示。 图5-9竞赛排名查询界面 图5-10后台竞赛排名查询界面 图5-11前台竞赛排名列表界面 图5-12前台竞赛排名详情界面 主要代码如下 PostMapping(/add) Transactional public MapString, Object add(HttpServletRequest request) throws IOException { service.insert(service.readBody(request.getReader())); return success(1); } Transactional public MapString, Object addMap(MapString,Object map){ service.insert(map); return success(1); } 管理员功能模块 管理员登录系统可以查看并操作以下功能主页个人资料公共管理轮播图公告信息用户管理管理员普通用户信息管理竞赛资讯资讯分类竞赛答题竞赛信息竞赛报名竞赛排行等。 图5-13管理员功能界面 竞赛信息管理员在此页面可以查看竞赛名称类型时间答题时长要求等信息。可以进行查询重置删除添加等操作。如下图所示。 图5-14竞赛信息管理界面 图5-15竞赛信息添加界面 关键代码如下所示。 PostMapping(/add) Transactional public MapString, Object add(HttpServletRequest request) throws IOException { service.insert(service.readBody(request.getReader())); return success(1); } Transactional public MapString, Object addMap(MapString,Object map){ service.insert(map); return success(1); } 竞赛答题管理员在此页面可以管理、维护竞赛题库信息启用或禁用答卷查看用户提交的答卷进行评分。可以进行查询重置删除添加等操作。如下图所示。 图5-16竞赛答题管理界面 图5-17启用界面 图5-18题库设计界面 图5-19评分界面 竞赛排名管理员在此页面可以录入、维护用户的竞赛成绩进行排名。如下图所示。 图5-20竞赛成绩录入界面 系统测试 测试目的 在对该系统进行完详细设计和编码之后就要对线上知识竞赛系统的程序进行测试检测程序是否运行无误反复进行测试和修改使之最后成为完整的软件满足用户的需求实现预期的功能。 测试过程 在软件的测试过程中通常测试人员需要针对不同的功能模块设计多种测试用例。通过测试用例能够及时发现代码业务逻辑上是否与真实的业务逻辑相对应及时发现代码上或逻辑上的缺陷以此来来完善系统提高软件产品的质量使软件具有良好的用户体验。 登录测试用例表如下所示。 表6-1登录测试用例 测试性能 用户或操作员登录系统 用例目的 测试用户或操作员登录系统时功能是否正常 前提条件 进入用户登录页面或操作员登录页面 输入条件 预期输出 实际情况 各项信息不予填写直接点击登陆按钮 不允许登录提示填写账号相关信息 一致 填写错误的登录名或密码后点击登录系统 提示用户名或密码错误要求重新填写进行登录 一致 填写与验证码信息不一致的信息 系统显示出提示信息表明验证码错误要求重新填写 一致 竞赛信息添加测试用例表如下所示。 表6-2竞赛信息添加测试用例 测试性能 用户进行竞赛信息添加的操作 用例目的 测试用户进行竞赛信息添加操作时该功能是否正常 前提条件 用户进入商品详情页该商品能够被添加 输入条件 预期输出 实际情况 对着某商品点击“添加”按钮 界面跳转至添加界面 一致 在添加界面输入必填项点击“提交”按钮 提示“添加成功”并返回上一级界面 一致 在添加界面填写添加表单的时候未输入完整点击“提交”按钮 提示“添加失败” 一致 竞赛题库添加测试用例表如下所示。 表6-3竞赛题库添加测试用例 测试性能 用户进行竞赛题库添加的操作 用例目的 测试用户进行竞赛题库添加操作时该功能是否正常 前提条件 用户进入商品详情页该商品能够被添加 输入条件 预期输出 实际情况 点击“添加”按钮 界面跳转至添加界面 一致 在添加界面输入必填项点击“提交”按钮 提示“添加成功”并返回上一级界面 一致 在添加界面填写添加表单的时候未输入完整点击“提交”按钮 提示“添加失败” 一致 竞赛排名管理测试用例表如下所示。 表6-4竞赛排名管理测试用例 测试性能 竞赛排名相关信息管理功能 用例目的 测试系统操作者对竞赛排名相关信息进行管理的功能是否正常 前提条件 登录系统进入相关管理页面 输入条件 预期输出 实际情况 进入竞赛排名管理界面点击“录入”按钮填写所有必填项点击提交 提示“录入成功”并返回查询界面 一致 进入竞赛排名管理界面点击“录入”按钮未填写一个或者多个必填项点击提交 提示“录入失败”请填写必填项 一致 进入竞赛排名管理界面选择要修改的一条数据点击该条数据后面的“修改”按钮 节目跳转至修改界面 一致 在修改界面修改可修改项后点击“提交”按钮 提示“修改成功”并返回查询界面 一致 进入竞赛排名管理界面点击某条数据后面的删除按钮 提示“是否要删除该数据”如果用户点击“确定”按钮则成功删除该条数据并提示“删除成功”之后返回查询界面 一致 测试结果 经过对此系统的测试得出该系统足以满足用户日常需求在功能项目和操作等方面也能满足操作员对于其他用户的管理。但是还有很多功能有待添加这个系统仅能满足大部分的需求还需要对此系统的功能更进一步的完善这样使用起来才能更加的完美。 总结与展望 通过线上知识竞赛系统的开发本人巩固了之前学过的知识如今将平时所学到的知识融合在设计中在设计过程中做了很多的准备首先在数据库系统的设计过程中尤其是在数据库的工作原理、工作特点对其深刻的讨论与此同时对于小型站点来说最好服务器的选择其次利用所学的知识点分析所做的系统并在此基础上设计。 目前本系统已经上线正在试运行阶段用户反馈良好基本完成用户所需试运行过程中没有出现阻断性问题有一些不足和小问题也及时予以修正系统上线后为了保证数据的安全性对系统进行了备份操作系统备份是每两个月备份一次数据库备份为每周备份一次系统部署在租赁的云平台服务器中。 本次系统上线成功后得到了用户的高度认可但是在功能上和性能上还需做进一步的研究处理使其有更高的性能和更好的用户体验。 系统在以后的升级过程中需要解决一系列用户所提出的问题例如打印过程中如何避免浏览器的兼容性问题大量用户访问时如何保持较高的响应速度在系统今后的升级过程中将着重解决这些安全性问题。 参考文献 [1]赵静.基于SSMVUE框架的企业合规管理系统[J].数字通信世界,2022(11):17-19. [2]阮眩龙,张汉权,韦贵凡,唐萍,张捷.基于SSM框架的奖学金评定管理系统设计[J].电脑编程技巧与维护,2022(08):106-109.DOI:10.16184/j.cnki.comprg.2022.08.025. [3]Zheng Hongying. A Study on the Design of English Speaking Examination System Based on SSM Framework[J]. Journal of Sensors,2022,2022. [4]刘源昭,陈伟,曹俊杰,李鹏宇,李英杰,许一靖,孙浩铭.基于SSM架构的图书管理系统[J].山西电子技术,2022(03):61-6376. [5]吴小芳.SSH框架下学科竞赛管理系统设计与实现[J].福建电脑,2022,38(05):73-77.DOI:10.16707/j.cnki.fjpc.2022.05.018. [6]陈恒,陈淑丽.基于SSM框架的学生档案管理系统的设计与实现[J].电脑知识与技术,2022,18(10):42-4347.DOI:10.14004/j.cnki.ckt.2022.0747. [7]朱彬,童颖飞,陈剑,肖苏飞.基于SSM的党建管理系统设计与实现[J].信息与电脑(理论版),2022,34(02):148-151. [8]杨正权.基于ASP.NET的网络综合布线技术课程线上竞赛管理系统设计[J].信息与电脑(理论版),2022,34(02):220-222. [9]李春生,李朝霞,刘涛,胡亚楠.基于SSM的科研室管理系统的研究与设计[J].计算机技术与发展,2021,31(12):148-154. [10]王宇,夏丽丽,何颖刚.基于SSM框架的高校毕业论文管理系统的设计与实现[J].电子技术与软件工程,2021(22):26-29. [11]侯军杰,杨威,陈畅.创新创业竞赛管理系统设计与实现[J].电子测试,2020(20):80-81.DOI:10.16520/j.cnki.1000-8519.2020.20.031. [12]沈佳棋,倪珊,王杰,丁洁.基于VueSpringBoot的分类学科竞赛管理系统设计[J].无线互联科技,2020,17(17):74-77. [13]任嘉,徐卓农,邓飞.对高校学科竞赛管理系统改进的研究[J].科技视界,2020(20):168-170.DOI:10.19694/j.cnki.issn2095-2457.2020.20.72. [14]刘伟,付元礼,黄辛迪,李小智,胡为.大学生学科竞赛管理系统的设计与实现[J].电脑知识与技术,2020,16(17):25-27.DOI:10.14004/j.cnki.ckt.2020.2057. [15]. Design and Implementation of ERP System Based on SSM Framework[J]. ,2020,440(5). [16]Ping Wanxin,Chen Yuankun,Hou Xiaoyan. Design of Campus Bicycle Rental Management System Based on SSM Framework[J]. Journal of Physics: Conference Series,2019,1314. [17]李志昕,马月坤.高校学科竞赛管理系统研发与应用[J].计算机产品与流通,2019(09):253. [18]Jihong W,Junmei W,Dongling S. Design and Research of University International Cooperation Office Platform Based on SSM Framework[C]//Jilin Province Science and Technology (ST) Innovation Center for Physical Simulation and Security of Water Resources and Electric Power Engineering,The Cooperative Innovation Center of Wind Power Equipment and Energy Conversion, Hunan Institute of Engineering,St. John’s University,Hunan Internet of Things Association.Proceedings of 2019 International Conference on Virtual Reality and Intelligent Systems (ICVRIS 2019) Volume I.Proceedings of 2019 International Conference on Virtual Reality and Intelligent Systems (ICVRIS 2019) Volume I,2019:229-232.DOI:10.26914/c.cnkihy.2019.011418. [19]卢瑛.基于“.NET技术”的体育竞赛管理系统设计与实现[J].自动化技术与应用,2019,38(08):162-165. [20]Di Lu,Yuping Qiu,Chun Qian,Xi Wang,Wei Tan. Design of Campus Resource Sharing Platform based on SSM Framework[J]. IOP Conference Series: Materials Science and Engineering,2019,490(6). 致谢
伴随着设计的完成大学生涯也随之即将结束。大学期间是我最珍惜的时光大学时光中学会了很多也成长了很多这段时光中每一段回忆都刻在脑海中。感谢一起学习一起成长同学们和成长过程悉心教导的老师们非常感激有你们的陪伴。
首先感谢我的指导老师设计的完成离不开老师的一系列指导。在毕业设计的完成过程中老师给出了很多中肯的建议正是由于老师一丝不苟的工作态度我的设计才能顺利的完成。
最后感谢在大学生涯中每一位教导我的老师是你们教给了我丰富的知识更教会了我遇到问题时如何去应对并解决。谢谢你们的帮助与支持。 请关注点赞私信博主免费领取项目源码