开发网站实训的心得体会,百度关键词优化外包,购物平台取名字,建站网站公司调查SSM德庆县乡村教育图书管理系统 摘 要 大数据时代下#xff0c;数据呈爆炸式地增长。为了迎合信息化时代的潮流和信息化安全的要求#xff0c;利用互联网服务于其他行业#xff0c;促进生产#xff0c;已经是成为一种势不可挡的趋势。在德庆县乡村教育图书管理的要求下数据呈爆炸式地增长。为了迎合信息化时代的潮流和信息化安全的要求利用互联网服务于其他行业促进生产已经是成为一种势不可挡的趋势。在德庆县乡村教育图书管理的要求下开发一款整体式结构的德庆县乡村教育图书管理系统将复杂的系统进行拆分能够实现对需求的变化快速响应、系统稳定性的保障能保证平台可持续、规模化发展的要求。 系统开发是采用java语言基于MVVM模式进行开发采取MySQL作为后台数据的主要存储单元采用SSM框架实现了本系统的全部功能。德庆县乡村教育图书管理系统解决了传统管理方式所带来的人力、物力和时间上的虚耗和交流深度的限定这让交流的过程更快捷、准确、便利同时完成德庆县乡村教育图书管理系统的基本功能书籍管理、用户注册管理、预订记录管理、借书还书管理、书籍捐赠管理。 关键词图书管理整体式结构Mysql数据库 SSM Deqing County Rural Education Book Management System Abstract In the age of big data, data is growing explosively. In order to meet the trend of the information age and the requirements of information security, it has become an irresistible trend to use the Internet to serve other industries and promote production. Under the requirements of rural education book management in Deqing County, a rural education book management system in Deqing County with an integrated structure is developed to split the complex system, which can achieve rapid response to changes in demand, guarantee the stability of the system, and ensure the sustainable and large-scale development of the platform. The system is developed based on MVVM mode using Java language, MySQL as the main storage unit of background data, and SSM framework to achieve all the functions of the system. The rural education book management system of Deqing County has solved the waste of manpower, material resources and time brought about by the traditional management method and the limit of communication depth, which makes the communication process more rapid, accurate and convenient. At the same time, it has completed the basic functions of the rural education book management system of Deqing County: book management, user registration management, reservation record management, book borrowing and returning management, book donation management. Key words:Library management; Integral structure; Mysql database 目 录 第1章 绪论 1.1 研究背景与意义 1.2 论文组成结构 第2章 开发工具及相关技术介绍 2.1 J2EE技术 2.2 MVVM模式 2.3 MySQL数据库 2.4 B/S结构 2.5 SSM框架 2.6 ssm框架各层关系 第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.4.1 概念模型设计 4.4.2 逻辑结构设计 4.4.3 数据库连接设计 第5章 系统实现 5.1 登录模块的实现 5.2 用户子系统模块的实现 5.3 管理员子系统模块的实现 第6章 系统测试 6.1 测试目的 6.2 测试用例 6.2.1 登录测试 6.2.2 注册测试 6.2.3 书籍管理测试 6.2.4 书籍预订测试 6.3 测试结果 第7章 总结与展望 参考文献 致谢 绪论 研究背景与意义 中国是一个农业大国农村人口居多为了提高农村教育水平实现农村义务教育的全覆盖促进农村经济发展中国乡村教育管理模式一直以县、乡、村分级管理这种教育管理模式极大地满足了农村教育水平也积极促进了农村义务教育对农村教育管理起到了积极的作用。但是近年来中国农村经济迅速发展城镇化水平加速对农村教育管理提出了新的挑战农村教育管理面对新的新形势下如何改革和创新教育管理成为当下农村教育改革亟待解决的一个问题。发展乡村教育是实施乡村振兴的内在要求也是构建美好乡村生活的出发点。乡村教育在中国全面教育中占有重要的比重,做好乡村教育有助于提升中国的整体教育质量。 德庆县乡村教育德庆县乡村教育图书管理系统充分利用网络的便利性可以不受时空的局限对图书进行随时随地的管理这个系统的开发很大程度地把图书的管理流程简化了同时也减轻了图书管理人员的工作量也提高了图书的利用率还为图书购买者提供了一个便利的捷径。本系统主要的优点体现在下面的几个方面 1管理员通过数据库管理和维护系统可以对借阅者和图书进行管理和维护。管理员可以对后台数据中的信息进行删除、修改、更新等基本操作以管理和维护借阅者信息。 2用户可以通过图书的名称、图书编号、作者、图书类型、出版社进行查询以方便用户对图书信息的快速检索。 3图书的添加新书的出版可以及时的输入数据库以待取用已经报废的旧书及时的删除或禁用。 4图书订单信息订单信息的录入管理。 论文组成结构 根据市场调研得到的信息数据结合国内外前沿研究利用相关系统开发和设计方法最终设计出德庆县乡村教育图书管理系统。 本文共有七章如下所示。 第一章概述了德庆县乡村教育图书管理系统的研究目的和意义精炼地总结了国内外在仓储领域的研究情况和未来的研究趋势最后给出了论文的组成结构。 第二章简要概述了本文所用的开发技术和工具。 第三章简要对系统各业务流程进行需求分析、可行性分析。 第四章对德庆县乡村教育图书管理系统进行设计。 第五章对德庆县乡村教育图书管理系统进行实现并贴出相关页面截图语言描述出具体功能实现的操作方法。 第六章对德庆县乡村教育图书管理系统采用测试用例的方式来对一些主要功能模块测试最后得出测试结果。 第七章总结全文并对未来的研究做出展望。 开发工具及相关技术介绍 开发技术 本系统前端部分基于MVVM模式进行开发采用B/S模式后端部分基于Java的ssm框架进行开发。 前端部分前端框架采用了比较流行的渐进式JavaScript框架Vue.js。使用Vue-Router和Vuex实现动态路由和全局状态管理,Ajax实现前后端通信Element UI组件库使页面快速成型项目前端通过栅格布局实现响应式可适应PC端、平板端、手机端等不同屏幕大小尺寸的完美布局展示。 后端部分采用ssm作为开发框架同时集成MyBatis、Redis等相关技术。 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的新特性糅合进去以应对客户日益复杂的需求变化。 Mysql数据库 Mysql 经过多次的更新功能层面已经非常的丰富和完善了从Mysql4版本到5版本进行了比较大的更新在商业的实际使用中取得了很好的实际应用效果。最新版本的Mysql支持对信息的压缩同时还能进行加密能更好的满足对信息安全性的需求。同时经过系统的多次更新数据库自身的镜像功能也得到了很大的增强运行的流畅度和易用性方面有了不小的进步驱动的使用和创建也更加的高效快捷。最大的变动还是进行了空间信息的显示优化能更加方便的在应用地图上进行坐标的标注和运算。强大的备份功能也保证了用户使用的过程会更加安心同时支持的Office特性还支持用户的自行安装和使用。在信息的显示形式上也进行了不小的更新增加了两个非常使用的显示区一个是信息区对表格和文字进行了分类处理界面的显示更加清爽和具体。第二是仪表的信息控件能在仪表信息区进行信息的显示同时还能进行多个信息的比对为用户的实际使用带来了很大的便捷。 针对本文中设计的德庆县乡村教育图书管理系统在实际的实现过程中最终选择Mysql数据库的主要原因在于在企业的应用系统应用及开发的过程中会存在大量的数据库比较频繁的操作而且数据的安全性要求也是非常的高。综合这些因素最终选择安全性系数比较高的Mysql来对德庆县乡村教育图书管理系统后台数据进行存储操作。 数据库管理系统的总体结构图如下图所示。 图2-1 数据库组成结构 B/S结构 B/SBrowser/Server比前身架构更为省事的架构。它借助Web server完成数据的传递交流。只需要下载浏览器作为客户端那么工作就达到“瘦身”效果 不需要考虑不停装软件的问题。 SSM框架 SSM即SpringMVVMSpringMySQL这三个框架有各自最独有的优势那么将它们组合在一起能够碰撞出很强的火花。设计者在不需消耗大量功夫能做出Web应用程序而且这个程序还具有层次清晰、升级更新操作不影响正常使用的、允许多次使用的特点。这个复合框架形成一个有着结构完整、功能强大和结构良好的体系SpringMVVM使各板块分离Spring使开发更灵活方便让开发者直接对对象进行操纵各层次分工明细并实现各个层次间的解耦让代码更加的灵活精简。这个框架使程序员能够规避在开发时期避免个别错误导致整体被破坏也能在后期应对客户对产品提出的新需求。 ssm框架各层关系 DAO层、Service层这两个层次都可以单独开发互相的耦合度很低完全可以独立进行这样的一种模式在开发大项目的过程中尤其有优势。 ControllerView层因为耦合度比较高因而要结合在一起开发但是也可以看作一个整体独立于前两个层进行开发。这样在层与层之前只需要知道接口的定义调用接口即可完成所需要的逻辑单元应用一切显得非常清晰简单。 系统分析 可行性分析 在软件开发的过程中系统的可行性分析是必不可少的可行性的研究就是评估问题是否能得到解决并且是要以最少的时间和最少的代价来解决。为实现上面的目标还要必须考虑到解决这些问题的方法的优点和缺点还要考虑到实现了这些系统规模的开发带来的经济效益。这里可以用技术的可行性操作的可行性经济的可行性对我们的系统进行可行性的研究。德庆县乡村教育图书管理系统的可行性分析如下所示 技术可行性 德庆县乡村教育图书管理系统采用的是Java编程语言并于SSM框架数据库部分采用的是当前流行的MYSQL数据库德庆县乡村教育图书管理系统中的所有数据资源都存储在Mysql数据库中不仅减少了服务器对页面的解析而且极大增加了用户的体验度。 经济可行性 德庆县乡村教育图书管理系统是在Mysql的环境中运行的而系统的成本也只是主要分布在软件的开发和维护上。但如果系统上线投入使用之后不仅可以方便人们还节省了用户的时间和精力而且还极大限度的方便了运营者减少了运营者的工作强度。德庆县乡村教育图书管理系统其实也不太复杂在开发的时候经济支出也不大在开发系统时时间用的也不多从时间的优势和对经济利益方面产生的好处远超过维护和管理的成本所以开发此系统是可行合适的。 操作可行性 本系统是基于浏览器和服务器的德庆县乡村教育图书管理系统系统开发完成之后用户只需要在浏览器中输入正确的URL地址即可进行访问。本系统的前台页面简单明了在没有操作指导的情况下也可以进行操作无论是系统管理员还是普通用户在页面中所有的操作都是在浏览器中完成的因此只要电脑在有网络的情况下打开浏览器都能操作。而且在使用之前也不用进行相关的环境配置因此本系统方便、简单、易于使用所以该系统是容易并且可操作的。 需求分析 根据用户对系统的需求要求系统简单操作能够准确完整的对信息进行管理。德庆县乡村教育图书管理系统在对需求做解析后整个系统主要分为两个部分管理员和普通用户每个模块下的分支功能不一样。对功能做出如下说明 管理员模块系统用户管理、书籍信息管理、书籍类型管理、借书还书管理、预订记录管理、取消预订管理、书籍捐赠管理。 用户模块图书资讯、书籍信息、书籍捐赠、书籍预订、取消预订、借书还书等。 系统用例图如下所示。 图3-1系统用例图 根据用例图对一些重要的用例进行描述。 注册用例描述如下表所示。 表3-1 注册用例描述 用例名称 注册 参与者 用户 描述 用户填写相关信息完成注册成为系统的用户 前置条件 无 后置条件 用户填写相关信息并用户账号可用 事件流 用户点击注册按钮用户填写相关信息用户确认并提交信息系统提示注册成功 补充说明 系统检测用户所输信息如不符合要求则提示并返回注册界面系统检测用户所输账号不可用或已存在则提示并返回注册界面 登录用例描述如下表所示。 表3-1 登录用例描述 用例名称 登录 参与者 用户 描述 用户填写用户名和密码登录系统 前置条件 用户已注册 后置条件 用户名和密码正确 事件流 1用户在登录页面输入用户名和密码 2系统检测用户输入的用户名和密码 3显示登录成功并返回主页面 补充说明 a系统检查除密码不正确返回登录页面 个人信息管理用例描述如下表所示。 表3-1 个人信息管理用例描述 用例名称 管理个人信息 参与者 用户 描述 用户查看、修改个人信息 前置条件 用户已登录 后置条件 无 事件流 1用户查看个人信息 2用户修改个人信息 补充说明 a用户可修改密码 b用户可修改联系方式 图书出借用例描述如下表所示。 表3-1 图书出借用例描述 用例名称 图书出借 参与者 用户 描述 用户执行图书出借操作 前置条件 用户已登录 后置条件 该图书存在并且能被借出 事件流 1在图书页点击要借的图书 2填写图书出借数据 补充说明 a图书出借表单数据不能为空 图书归还用例描述如下表所示。 表3-1 图书归还用例描述 用例名称 图书归还 参与者 用户 描述 用户执行图书归还操作 前置条件 用户已登录 后置条件 该图书存在并且能被归还 事件流 1在图书页点击要归还的图书 2填写图书归还数据 补充说明 a图书归还表单数据不能为空 书籍用例描述如下表所示。 表3-1 书籍用例描述 用例名称 书籍管理 参与者 管理员 描述 管理员提供新增、修改、删除书籍等功能 前置条件 管理员成功登录系统管理员只能对已存在的书籍进行修改和删除 后置条件 无 事件流 (1)管理员查看修改书籍 (2)管理员添加书籍 (3)管理员删除书籍 补充说明 (a)新添加的书籍不符合要求时会添加失败 (b)修改的书籍不符合要求时会修改失败 系统业务流程分析 德庆县乡村教育图书管理系统的业务流程如下图所示。 图3-3 系统业务流程图 管理员拥有最高权限在对各项信息进行增加、删除、修改后会更新后台数据库的内容用户在登录进行书籍查看、书籍分类、书籍预订管理、书籍捐赠、图书借出、图书归还录入操作等指令动作同样会更新后台数据。 系统数据流程分析 与强调控制逻辑的程序流程图不同它更关心的是整个系统中数据的具体流动以及数据的加工处理的整个客观过程是对数据规格的说明。也正因如此系统数据流图作为系统结构化分析方法中极为重要的一种描述工具备受青睐。 德庆县乡村教育图书管理系统的系统原理图如下图所示。 图3-4系统原理图 外部实体为用户第一个流程为登录验证用户信息表返回密码验证是否正确正确则登录系统错误则反馈信息登录系统后根据不同用户的功能选择来读写数据库。 系统底层数据流如下图所示。 图3-5系统底层数据流图 系统底层数据流外部实体为管理员和用户数据流分别有管理员和用户流向系统数据流程数据表提供数据支持来完成逻辑操作。 系统设计 系统架构设计 由于本系统在逻辑事务处理方面对数据库的操作比较频繁所以系统在底层连接数据库封装之后相当于一个连接数据库的工具DB UTIL这样使用起来会更加方便而且这样进行封装还可以降低系统中代码的冗余当我们需要连接和使用数据库时只需要调用这个工具里面的一个方法就可以了。而且通过封装可以把对数据库的操作独立起来当需要连接不同种类的数据库时只需要加以修改就可以达到目的。 DAO层本来并无这个类它只是Java中MVC构造里的一个model概念主要就是里面的一些方法而这些方法就是用来访问数据库的方法。我们在软件开发时DAO层我们一般都放接口和接口的实现类用于来规范实现类的我们叫它接口实现类重点用于对数据库的操纵。 MVC是一种系统研发的关键模型M是Model模型它是系统内部关键程序运行的核心主要进行对数据库的各种操作。视图View是V也叫做视图主要的作用是对一些数据进行显示。控制器Controller 是C执行从View的视图层来读取数据然后控制用户的输入。 图4-1系统架构图 系统功能结构 进入系统后首先要进行登录验证你的身份赋予你不同的权限。当你成功登录后页面会有多个板块分别是系统用户管理、书籍管理、书籍分类管理、书籍预订管理、取消预订管理、借书管理、还书管理、书籍捐赠管理。里面界面简单易懂根据标示可以直接进行方便快捷的操作。 系统功能结构图如下所示。 图4-1系统功能结构图 数据库设计 一个好的系统它的后台数据库一定要考虑的全面这和我们建造房子一个概念房子不是随心所欲建起来的一切都是在合理设计的基础是实现的地基打牢固了房子才能建的更高。数据库如果设计的很合理而且每个方面都能考虑到了那么这个系统才能不会出现大的问题。 概念模型设计 本系统在数据库中存放了多张表分别是用户表、书籍表、预订表、取消预订表、借书表、归还表、捐赠表。 系统的主要实体间关系E-R图如下图所示。 图4-7系统E-R图 逻辑结构设计 此环节把概念转变成数据。由于整个数据库所处理的信息过多就只展示几个表。book_information表 名称 类型 长度 不是null 主键 注释 book_information_id int 11 是 是 书籍信息ID book_number varchar 64 是 否 书籍编号 book_type varchar 64 否 否 书籍类型 title varchar 64 否 否 书名 author varchar 64 否 否 作者 press varchar 64 否 否 出版社 location varchar 64 否 否 所在位置 book_introduction text 0 否 否 图书简介 book_cover varchar 255 否 否 图书封面 hits int 11 是 否 点击数 praise_len int 11 是 否 点赞数 recommend int 11 是 否 智能推荐 create_time datetime 0 是 否 创建时间 update_time timestamp 0 是 否 更新时间 book_donation表 名称 类型 长度 不是null 主键 注释 book_donation_id int 11 是 是 书籍捐助ID user_no int 11 否 否 用户编号 user_name varchar 64 否 否 用户姓名 book_name varchar 64 否 否 书籍名称 book_type varchar 64 否 否 书籍类型 address varchar 64 否 否 地址 name_of_sender varchar 64 否 否 寄件人姓名 telephone varchar 16 否 否 电话 book_cover varchar 255 否 否 图书封面 examine_state varchar 16 是 否 审核状态 examine_reply varchar 16 否 否 审核回复 recommend int 11 是 否 智能推荐 create_time datetime 0 是 否 创建时间 update_time timestamp 0 是 否 更新时间 book_return_record表 名称 类型 长度 不是null 主键 注释 book_return_record_id int 11 是 是 还书记录ID loan_no varchar 64 是 否 借书编号 book_number varchar 64 否 否 书籍编号 book_type varchar 64 否 否 书籍类型 title varchar 64 否 否 书名 author varchar 64 否 否 作者 press varchar 64 否 否 出版社 borrowing_time date 0 否 否 借书时间 actual_return_time date 0 否 否 实际还书时间 user_no int 11 否 否 用户编号 user_name varchar 64 否 否 用户姓名 book_cover varchar 255 否 否 图书封面 recommend int 11 是 否 智能推荐 create_time datetime 0 是 否 创建时间 update_time timestamp 0 是 否 更新时间 borrowing_record表 名称 类型 长度 不是null 主键 注释 borrowing_record_id int 11 是 是 借书记录ID reservation_no varchar 64 否 否 预订编号 loan_no varchar 64 否 否 借书编号 book_number varchar 64 否 否 书籍编号 book_type varchar 64 否 否 书籍类型 title varchar 64 否 否 书名 author varchar 64 否 否 作者 press varchar 64 否 否 出版社 user_no int 11 否 否 用户编号 user_name varchar 64 否 否 用户姓名 book_cover varchar 255 否 否 图书封面 recommend int 11 是 否 智能推荐 create_time datetime 0 是 否 创建时间 update_time timestamp 0 是 否 更新时间 cancel_the_reservation表 名称 类型 长度 不是null 主键 注释 cancel_the_reservation_id int 11 是 是 取消预订ID reservation_no varchar 64 是 否 预订编号 book_number varchar 64 否 否 书籍编号 book_type varchar 64 否 否 书籍类型 title varchar 64 否 否 书名 author varchar 64 否 否 作者 user_no int 11 否 否 用户编号 user_name varchar 64 否 否 用户姓名 book_cover varchar 255 否 否 图书封面 recommend int 11 是 否 智能推荐 create_time datetime 0 是 否 创建时间 update_time timestamp 0 是 否 更新时间 reservation_record表 名称 类型 长度 不是null 主键 注释 reservation_record_id int 11 是 是 预订记录ID reservation_no varchar 64 否 否 预订编号 book_number varchar 64 否 否 书籍编号 book_type varchar 64 否 否 书籍类型 title varchar 64 否 否 书名 press varchar 64 否 否 出版社 author varchar 64 否 否 作者 user_no int 11 否 否 用户编号 user_name varchar 64 否 否 用户姓名 book_cover varchar 255 否 否 图书封面 recommend int 11 是 否 智能推荐 create_time datetime 0 是 否 创建时间 update_time timestamp 0 是 否 更新时间 return_request表 名称 类型 长度 不是null 主键 注释 return_request_id int 11 是 是 还书请求ID loan_no varchar 64 是 否 借书编号 book_number varchar 64 否 否 书籍编号 book_type varchar 64 否 否 书籍类型 title varchar 64 否 否 书名 author varchar 64 否 否 作者 press varchar 64 否 否 出版社 request_for_return_time date 0 否 否 请求还书时间 user_no int 11 否 否 用户编号 user_name varchar 64 否 否 用户姓名 book_cover varchar 255 否 否 图书封面 examine_state varchar 16 是 否 审核状态 examine_reply varchar 16 否 否 审核回复 recommend int 11 是 否 智能推荐 create_time datetime 0 是 否 创建时间 update_time timestamp 0 是 否 更新时间 book_type表 名称 类型 长度 不是null 主键 注释 book_type_id int 11 是 是 书籍类型ID book_type varchar 64 否 否 书籍类型 recommend int 11 是 否 智能推荐 create_time datetime 0 是 否 创建时间 update_time timestamp 0 是 否 更新时间 数据库连接设计 该系统的数据库连接方法采用的是C3P0数据连接池的方法C3P0是开源的JDBC连接池jdbcURL是所创建的数据库driverClass连接数据库驱动user为用户名password为用户密码acquireIncrement当连接池中的连接耗尽的时候C3P0一次同时获取的连接数initialPoolSize初始化连接池中的连接数minPoolSize和maxPoolSize分别是连接池中保留的最小和最大的连接数。C3P0的特点在于有自动回收空闲连接的功能。 系统实现 登录模块的实现 该登录模块利用js进行设计JavaScript函数CheckSubmit()对输入框是否为空进行验证使用js的技术结合Mysql 2012数据库的查询语句进行登录信息的验证。首先从文本框中分别获得账号user_name和密码user_pw将查询结果赋给rs结果集若rs.next()返回值为空表示数据库找不到该用户数据若rs.next()返回值不为空则显示登录成功进入主界面。 用户登录流程图如下所示。 图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首页载入流程 首页载入流程系统先连接数据库显示界面参数初始化读取数据库的数据表显示前端样式对数据按添加时间排序按照模板设计位置显示数据刷新显示界面断开数据库连接。 首页如下图所示。 图5-4首页界面 用户注册模块 系统的用户通过自行注册生成在系统首页点击用户注册菜单系统跳转到对应的注册页面。点击重置按钮清空所填数据点击注册按钮完成注册。 用户注册流程图如下所示。 图5-5用户注册流程 注册个人信息实现流程为填写个人信息系统使用JQuery选择器获取在网页中输入的注册信息再对联系方式、登录密码等信息进行验证验证通过后用Ajax异步请求方式向服务器发送请求并把数据传送到后台然后验证用户名是否已存在如果已存在则注册失败提示“用户名已存在”如果用户表中没有该用户名则把用户信息加入数据库把操作状态以json字符串方式返回到前台。Ajax请求成功接收到返回的数据时会触发成功回调函数然后解析返回的json字符串系统根据返回信息弹出提示框注册成功后返回登录页。 用户注册界面如下图所示。 图5-6用户注册界面 用户注册关键代码如下所示。 /** * 注册 * return */ PostMapping(register) public MapString, Object signUp(HttpServletRequest request) throws IOException { // 查询用户 MapString, String query new HashMap(); MapString,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 MapString,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(MapString,Object body){ E entity JSON.parseObject(JSON.toJSONString(body),eClass); baseMapper.insert(entity); log.info([{}] - 插入操作{},entity); } 书籍添加模块 管理员进行书籍添加等在书籍模块实现书籍的信息添加管理员管理系统的所有书籍信息在列表p实现书籍的管理。 书籍添加流程图如下所示。 图5-7信息书籍流程 管理员登录成功后浏览书籍信息页面输入书籍名称添加该书籍信息修改书籍信息返回书籍相关界面。 书籍添加界面如下图所示。 图5-8书籍添加界面 借书记录模块 用户可以在线进行借书申请提交通过id传参找到该书籍在借书添加页提交借书申请单。 借书流程如下图所示。 图5-9借书流程 借书记录界面如下图所示。 图5-10借书记录界面 借书记录界面逻辑代码如下 public MapString, Object success(Object o) { MapString, Object map new HashMap(); if (o null) { map.put(result, null); return map; } if (o instanceof List) { if (((List) o).size() 1) { o ((List) o).get(0); map.put(result, o); }else { String jsonString JSONObject.toJSONString(o); JSONArray objects service.covertArray(JSONObject.parseArray(jsonString)); map.put(result, objects); } } else if (o instanceof Integer || o instanceof String) { map.put(result, o); } else { String jsonString JSONObject.toJSONString(o); JSONObject jsonObject JSONObject.parseObject(jsonString); JSONObject j service.covertObject(jsonObject); map.put(result, j); } return map; } 还书请求模块 用户在线进行书籍归还提交通过id传参找到该书籍在还书请求添加页提交还书表单。 还书流程如下图所示。 图5-11还书流程 还书请求界面如下图所示。 图5-12还书请求界面 还书请求界面逻辑代码如下 public MapString, Object error(Integer code, String message) { MapString, Object map new HashMap(); map.put(error, new HashMapString, Object(4) {{ put(code, code); put(message, message); }}); return map; } 管理员子系统模块的实现 管理员主页模块 经过用户登录后页面跳转至管理员功能模块页。 主界面如下图所示。 图5-13主界面 系统用户管理模块 管理员对系统用户的管理在列表实现管理员用户的管理包括录入、删除、修改修改密码通过SESSION获取用户名然后输入新密码提交使用sql命令更新密码。 用户管理界面如下图所示。 图5-14用户管理界面 用户管理界面逻辑代码如下 RequestMapping(/get_list) public MapString, Object getList(HttpServletRequest request) { MapString, Object map service.selectToPage(service.readQuery(request), service.readConfig(request)); return success(map); } 预订记录管理模块 用户在系统前台后添加书籍预订管理员在订单列表审核用户提交的书籍订单审核通过预订成功。 预订记录管理如下图所示。 图5-15预订记录管理界面 预订记录管理界面关键代码如下 RequestMapping(/get_obj) public MapString, Object obj(HttpServletRequest request) { List resultList service.selectBaseList(service.select(service.readQuery(request), service.readConfig(request))); if (resultList.size() 0) { JSONObject jsonObject new JSONObject(); jsonObject.put(obj,resultList.get(0)); return success(jsonObject); } else { return success(null); } } 书籍信息管理模块 管理员在tushuxinxi_add.jsp发布书籍跳转至书籍添加表单提交书籍信息包括书籍编号、名称、类别、作者图书封面等信息提交后数据库的书籍信息表刷新数据系统将书籍信息展示出来。 书籍信息管理的流程如所示。 图5-16书籍信息管理流程 书籍信息管理的界面如所示。 图5-17书籍信息管理界面 书籍类型管理的界面如所示。 图5-18书籍类型管理界面 书籍信息管理界面关键代码如下 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); } 新增一条数据通过post传入一个json对象然后经过request.getReader()最后经过readBody()转成一个Map含有String和Objectkey用的是字段名Object存放数据最终得到Mapinsert用拼装sql读取body组装成一个insert对象runCountSql()语句 系统测试 测试目的 在这个产品被投入使用前首先需要进行试用这是重要的环节。考虑到某个部分的开发没有缺陷情况下把各种模块拼接也有一定概率就存在矛盾。这就好比每个人都很独特但聚在一起就显得杂乱无章需要保证有默契的配合。对于测试要看它的各项内容是否契合的原则。若与最初定下的标准有一定程度上的出入那么就需要做出一些调整让最终的大方向朝着目标前进。 测试用例 登录测试 登录测试用例如下表所示。 表6-1登录测试用例 输入 输出 用户名 密码 空 空 用户名和密码不能为空 Kkk aaa 用户名长度不允许请重新输入 2109402315 123456 用户名出错请重新输入 sssss 123456 用户名出错请重新输入 注册测试 注册测试用例如下表所示。 表6-2注册测试用例 输入 输出 用户名 密码 确认密码 邮箱 空 空 空 空 用户名和密码不能为空 Kkk aaa aaa 23qq.com 注册成功 210 aaa abc 23qq.com 注册失败两次密码不一致 书籍管理测试 书籍测试用例如下表所示。 表6-3添加书籍测试用例 输入 输出 名称 类别 作者 备注 空 空 空 空 添加失败 书籍1 A 罗贯中 你好 添加成功 空 A 罗贯中 你好 添加失败名称不能为空 书籍2 空 罗贯中 你好 添加失败请选择类别 图书预订测试 图书预订测试用例如下表所示。 表6-4图书预订测试用例 输入 输出 名称 类别 预订人 备注 空 空 空 空 添加失败 图书1 A 111 你好 添加成功 空 A 111 你好 添加失败名称不能为空 图书2 空 111 你好 添加失败请选择类别 测试结果 经过测试得到测试结果如下表所示。 表6-5测试结果 序号 测试项目 内容和目的 测试结果 用户登录 输入正确用户名与密码 可以登录 输入错误用户名与密码 提示错误的信息 书籍管理 添加修改删除 输入正确信息 成功完成 输入错误信息 操作失败 修改登录密码 修改新的密码 成功完成 书籍预订管理 添加修改删除 输入正确信息 成功完成 输入错误信息 操作失败 借书记录管理 添加修改删除 输入正确信息 成功完成 输入错误信息 操作失败 书籍类型管理 添加修改删除 输入正确信息 成功完成 输入错误信息 操作失败 还书记录管理 添加修改删除 输入正确信息 成功完成 输入错误信息 操作失败 总结与展望 本次毕业论文的主要是利用SSMMySQL开发一个安全可靠操作简易同时具备业务可扩展的德庆县乡村教育图书管理系统。本文详细的论述了德庆县乡村教育图书管理系统的设计和开发本系统的所有事务逻辑都是按照系统的需求分析进行设计的系统有普通用户和系统管理员两种角色本系统多处采用了Ajax的异步交互技术同时它也叫异步交互技术利用它我们可以让网页的局部进行数据刷新操作Ajax和传统的数据更新技术大大增加了客户的体验程度由于是对局部进行操作那么就减少了一些繁琐而又不必要的操作减轻了服务器对页面解析的负担。 与其他系统相比本系统有自身的优点 例如 1创新性强 2业务逻辑性强安全性高在一些重要的功能模块需要通过审查之后才可使用 3移植性高在所有window平台都可使用。 当然也还有很多需要进一步改进的地方 1系统大多数页面都是全局刷新缺乏局部刷新这将增加服务器的压力如果有大量用户在同一时间段操作同一个功能模块可能会导致查询缓慢 2页面没有经过专业的UI设计美观程度不及其他市场其他网站系统有待改善。 参考文献 [1]段学敏,高卫辉.图书管理与信息化结合途径初探[J].参花(下),2022(02):122-124. [2]王小刚.互联网时代下的学校图书管理信息化建设[J].数字通信世界,2022(02):122-124. [3]李鹏.新公共管理理念在图书管理中的创新应用[J].产业与科技论坛,2022,21(03):285-286. [4]林辉.基于Java Web的渭南市大荔县图书管理系统的设计与实现[J].电子设计工程,2021,29(24):155-158163. [5]李东阳.利用信息技术优势做好图书管理工作[J].新课程,2021(50):216. [6]冯晓娟.信息技术在图书管理中的运用研究[J].文化产业,2021(33):40-42. [7]王丹.大数据时代公共图书管理的创新路径[J].传媒论坛,2021,4(22):146-148. [8]罗莉霞,高何裕.基于B/S的高校图书管理与个性化推荐系统的设计与实现[J].技术与市场,2021,28(11):184-185. [9]杜秋英.基于网络环境下公共图书馆图书管理的措施[J].科技资讯,2021,19(30):146-148. [10]黄波.基于SSM乡村教育图书管理系统设计与实现[J].信息与电脑(理论版),2021,33(19):124-126. [11]何冰,刘瑞华.探索新媒体时代公共图书管理的有效途径[J].办公室业务,2021(19):172-173. [12]岳晓玲.浅论信息化建设视角下的图书管理[J].文化产业,2021(25):85-87. [13]曾莹珊.中职学校图书管理信息化建设的必要性与实现路径[J].新课程教学(电子版),2021(16):155-156. [14]李燕.图书管理工作中存在的问题和解决措施[J].办公室业务,2021(15):161-162. [15]张雪红.互联网时代图书管理信息化建设策略研究[J].中国高新科技,2021(14):39-40. [16] Li Dongyang Make use of the advantages of information technology to do a good job in library management [J] New curriculum, 2021 (50): 216 [17] Feng Xiaojuan Research on the application of information technology in library management [J] Cultural industry, 2021 (33): 40-42 致谢
经过几个月时间的努力终于完成了这篇文章在文章的写作与研究的过程中遇到了很多困难都在同学和老师的帮助下解决了。尤其非常感谢我最敬爱的老师他对我进行了无私的指导和帮助不厌其烦的帮助进行文章的修改。老师严谨的治学态度、渊博的学术知识、诲人不倦的敬业精神以及宽容的待人风范使我获益颇丰。此外在校图书馆查找资料的时候图书馆的老师也给我提供了很多方面的支持与帮助。在此向帮助和指导过我的老师表示最衷心的感谢感谢这篇文章所涉及到的各位学者。本文引用了数位学者的文献如果没有各位学者的研究成果的帮助和启发我将很难完成本篇文章的写作。感谢我的同学、朋友以及所在单位的同事在我写文章的过程中给与了我很多素材和帮助还在文章的撰写和排版过程中提供热情的帮助。同时感谢我的室友对我的热心指导和帮助经常有不懂之处都是大家在帮助我才使得我比较顺利的完成了这篇文章。由于我水平有限所写文章难免有不足之处恳请各位老师和学友批评和指正 请关注点赞私信博主免费领取项目源码