管理系统设计开发与学习

目录

封面

一.内容简介

二.技术概述

1.Spring Boot

2.MVC模式

3.数据库技术

4.Web前端技术

5.对接技术

四.体系架构

设计架构

系统分层

系统结构

五.数据库的设计

六.开发准备

开发工具

开发环境

七.学习总结

八.学习心得

一.内容简介

基于SpringBoot和KAQ模型的大学生成长平台,旨在帮助大学生提高综合素质,培养能力、知识和品质。基于以下相关技术进行理论学习,为日后开发做好准备。

1.系统架构设计:根据需求分析,设计系统的整体架构。前端采用Vue.js主流前端框架,后端采用SpringBoot作为开发框架,数据库使用MySQL。

2.搭建开发环境:配置好Java、SpringBoot、MySQL等开发环境,确保能够顺利进行后续的开发工作。

3.数据库设计:根据需求,设计数据库表结构,包括用户表、课程表、实践活动表、社区帖子表等。

4.前后端开发:利用SpringBoot框架,开发后端接口,实现用户注册、登录、课程学习、实践活动发布、社区交流等功能;利用Vue.js前端框架,开发前端页面,实现用户的操作界面。

5.接口对接:将前端页面与后端接口进行对接,确保系统能够正常运行。

二.技术概述:

1.Spring Boot 

Web开发经过多年的技术选型,Spring Boot渐渐进入开发者的视野,成为目前很多大公司进行Web开发的必选技术。 Spring Boot框架是由Pivotal团队所开发的。使用该框架可以迅速构建出一个能够独立运行、准生产级别的基于Spring技术的项目。它提供了以下核心功能:

  1. 自主运行的项目:Spring Boot可以将开发完成的程序直接打包成jar     包来运行,跟平时运行java项目没什么区别。

(2)内部提供了servlet容器:Spring Boot框架内部提供了Tomcat等servlet容器,使项目的部署变得更加方便。

(3)减少配置:Spring Boot采用“约定大于配置的理念”,开发人员能够尽可能少地编辑配置文件。

当然,在一些特殊的开发环境下,有些配置还是需要开发人员手动进行的。 Spring Boot框架的核心模块是由Spring框架提供的,Spring提供对控制反转、面向切面的编程AOP、容器管理、MVC框架、事务管理和异常处理的支持。Spring框架由核心容器(Core Container)模块、面向切面编程(AOP和Aspects)模块、数据访问/整合(Data Access/Integration)模块、Web模块和测试(Test)模块组成。

  1. 测试模块:实现应用程序的测试需求,支持开源测试框架Junit,访问以及相关Web服务。
  2. Web模块:提供了应用开发所需要的基础功能,包括支持多种格式的文件上传、远程过程发送和接受服务的支持。
  3. 事务模块:实现Spring框架中的事务管理功能,对象关系模型的支持。
  4. OXM模块:支持数种开源对象XML模型框架。
  5. JMS模块:提供对消息数据访问/整合模块中,JDBC实现一个通用的Java数据库连接模板。
  6. ORM模块:提供对耦合,指针对项目开发过程中的某一步骤或者阶段进行提取,实现业务处理过程各个阶段之间的低面向切面编程(AOP和Aspects)模块提供对面向切面编程的实现。面向切面的编程是Language模块提供对表达式语言的支持,功能并提供对应用资源的绑定、数据验证和国际化等特性的支持。
  7. Spring Expression 括服务器的资源访问和一些常见的工具类。
  8. Spring Context模块:集成了Spring Beans模块的(IOC)和依赖注入(DI)的实现。
  9. Spring Core模块:实现Spring框架的最基础部分,主要包核心容器模块。
  10. Spring Beans模块:实现Spring框架的核心部分,主要包括对控制反转。

2.MVC模式

MVC是一种软件的设计规范,用一种将页面、业务逻辑和数据库分离的模式来编写代码。MVC其实就是Model、View与Controller三个单词的缩写,分别代表着模型、视图页面与控制器。其中,模型是系统中用于处理应用程序数据逻辑的部分;视图页面是用户在使用中能直观感受到的模块,常用的视图页面包含了JSP、freeMarker和Thymeleaf等技术;控制器是系统中处理用户交互的部分。MVC模式的工作流程如下:

它的工作流程大致是这样的:用户在进行业务操作时会给控制器发出指令,控制器将这些指令以及相关数据传送给模型,模型根据这些指令对业务逻辑进行判断并且与数据库进行交互,完成后根据业务逻辑选择不同的视图页面并发送处理完的数据,视图页面将处理完的结果通过前端技术展现给用户。在此,Spring提供了一款出色的基于MVC模式的框架——SpringMVC。

3.数据库相关技术

3.1 My SQL

MySQL已经成为世界上最受欢迎的数据库管理系统之一。无论是用在小型项目开发上,还是用来构建那些声名显赫的网站,MySQL都已经被证明是一个稳定、可靠、快速和可信的系统,足以满足任何数据存储业务的需求。 MySQL在世界范围内得到了广泛的使用,它有如下特点:

(1)成本低:MySQL是开放源代码的,一般可以免费使用,甚至可以免费修改。

(2)性能高:MySQL的执行速度非常快。

(3)可信赖:目前世界上很多大型的公司或者网站都使用了MySQL作为其数据库管理系统,并且用其处理非常重要的数据。

(4)易操作:MySQL安装和使用非常方便。 

3.2 My Batis

MyBatis3之前的版本叫ibatis,原本是Apache下的一个项目,后来被谷歌公司托管,随即改名为MyBatis。MyBatis是一款非常优秀的持久层框架,所谓持久层框架,就是负责与数据库进行交互的框架。持久层的技术有很多,例如JDBC、Hibernate和MyBatis等。下面将各种持久层技术的使用流程进行对比来说明使用MyBatis的好处:

(1)JDBC

传统的JDBC技术使用起来非常复杂,大致要经历编写sql语句、预编

译、设置参数、执行sql语句和封装结果这五个步骤。它可以实现的功能非常少,而且采用了硬编码、高耦合的方式,将sql语句编写在java代码中,使后期维护变得非常困难。

  1. Hibernate

Hibernate是一个全自动ORM框架,ORM框架将javaBean对象映射到数据库中的每一条记录,使它们一一对应。如上图所示,Hibernate也需要经历与JDBC相同的步骤,不过与JDBC不同的是,Hibernate将这些步骤全部封装起来进行黑箱操作,用户感觉不到经历了这些步骤,所以称之为全自动框架。但是,Hibernate将编写sql语句也封装了起来,由框架自己发送sql语句,这样便造成了sql语句无法优化的后果。而且,几乎所有的项目都需要使用到一些复杂的定制sql语句,要想使用Hibernate达到这个目的,则必须要对Hibernate提供的HQL语句非常精通,这无疑又增加了开发者的学习负担。

(3)MyBatis

MyBatis是一个半自动的ORM框架。如上图所示,MyBatis与Hibernate最大的不同就是它将编写sql语句抽取出来并以配置文件的形式呈现,即将sql语句单独写在配置文件中。这就改变了Hibernate中由框架发送sql语句的做法,而将这个权力交给了开发者。这样使sql语句与java编码分离,方便后期维护。使用MyBatis只需要掌握sql语句的使用,无须学习其他的语句,减轻了开发者的学习负担。

4.Web前端技术

Web前端就是展现给用户的部分,即客户端或者浏览器端的部分。在一个基本管理系统的开发中主要使用了如下Web前端技术:

语言:

  1. JavaScript:它是一种直译式的脚本语言,是一种动态类型、弱类型、基于原型的语言,广泛用于客户端的脚本语言中。最早是在HTML网页上使用,可以给HTML网页增加动态功能。

(2)Ajax:它不是一种新的编程语言,而是一种用于创建更好更快以及交互性更强的Web应用程序的技术。Ajax在浏览器与Web服务器之间使用异步数据传输(HTTP请求),这样就可使网页从服务器请求少量的信息,而不是整个页面。例如,在网站注册的时候,有时输入用户名后,网页上会提示该用户名已被注册,这种效果就是通过Ajax来实现的,全程没有经过页面的跳转。

(3)CSS:它是网页的“装饰工”,通常使用html技术编写的网页十分单调,CSS可以给网页增加样式,增强用户的体验。

(4)html5:它是万维网的核心语言,用来编写Web网页。

(5)iframe:它的作用是将整个页面分成不同的框架,每个框架中都可以加载一个网页,实现了网页的嵌入。

(6)bootstrap:它将一些html5/CSS进行了简单的封装,使用bootstrap后,开发者可以在没有美工的修饰下做出漂亮的网页。

框架:

Vue.js 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue被设计为可以自底向上逐层应用。Vue的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与现代化的工具链以及各种支持类库结合使用时,Vue 也完全能够为复杂的单页应用提供驱动。简单来说,其实Vue就是用尽量简单的API来实现响应的数据绑定和组合的视图组件,所以我们在实际看Vue的实例,就会发现它的逻辑实现方法不是传统的先有HTML元素,再通过JavaScript来操作DOM;它恰好是反过来的,是先有Vue的逻辑,然后通过关键字绑定对应的HTML元素,并不操作实际的DOM,而是虚拟DOM。由于web是本学期选修课,故在此不再进行学习。

  1. 对接技术

“前后端对接”涉及将前端和后端协调工作,以实现应用程序的完整功能。这包括通过API(应用程序编程接口)或其他通信方式进行数据交换、数据验证、身份验证和授权,以及确保前端和后端的数据和状态同步。通常情况下,前后端之间的交互是通过HTTP协议进行的。HTTP(Hypertext Transfer Protocol)是一种用于在客户端和服务器之间传输数据的协议,广泛用于Web应用程序中。通过HTTP,前端可以向后端发起请求,并接收来自后端的响应。

对接中关于http的关键点,前端需要经常请求的信息就是http请求:

  • 请求消息(HTTP Request Message):
  • 请求行(Request Line):包括请求方法(GET、POST、PUT,DELETE等)、请求的资源路径(URL)和协议版本(HTTP/1.1等)。
  • 请求头部(Request Headers):包含关于请求的元信息,如User-Agent(用户代理)、Host(主机)、Content-Type(内容类型)等。
  • 空行(Empty Line):请求头部与消息主体之间需要有一个空行。
  • 消息主体(Message Body):可选的,包含发送到服务器的数据,通常在POST请求中使用,例如表单数据或JSON数据。

前端中我们需要经常对请求头,请求体,以及请求方式进行修改处理,最后发送到后端接口处。后端收到前端发送的请求后,会根据请求的头部(Headers)、正文(Body)和请求方式(Method)进行相应的处理。

一旦后端处理完请求,它会根据业务逻辑返回相应的响应。响应可能包括状态码、响应头和响应体。

四.体系架构:

在系统的概要设计阶段,需要确定系统的结构。确定一个系统的结构需要从多个层面入手。以下将从系统的设计架构、系统分层以及系统的包结构三方面来介绍。

设计架构:

采用了B/S架构,即浏览器/服务器架构。在这种架构下,用户通过浏览器输入地址来进入系统,大部分的业务处理任务放在服务器端,浏览器端只进行少部分的业务处理。使用B/S架构可以有以下好处:

(1)可以省去客户端的开发,减少了开发系统的工作量;在后期维护中,由于所有的客户端均为浏览器,所以只需要对服务器进行维护,降低了维护的难度。

(2)B/S架构中的各部分组件相对独立,因此采用该架构的系统具有非常好的重用性。

(3)B/S架构建立在广域网上,不需要使用特定的硬件来提供专门的网络环境。

系统分层:

在对系统架构设计完成的基础上,使用MVC模式对系统进行分层,将整个系统分成表现层、业务逻辑层和数据访问层。

系统各层之间相互独立,在对于各层的设计中可以不用考虑其他层。每层的分工十分明确:

表现层要求将页面设计得美观、简洁,符合用户需求,增强用户体验。

业务层主要负责对业务进行处理,实现相应的功能。

数据访问层不包含任何对业务的处理,只负责与数据库中的实体进行交互,即对数据库中的表进行增删改查。

最初展现在用户面前的是登录页面,当用户登录后便会进入包含着许多业务的主页面;当用户操作某个业务时,系统就会向服务器发出请求,服务器便会调用业务逻辑层来对该请求所代表的业务进行处理,处理完成后服务器将处理的结果返回给表现层中的页面;在业务逻辑层进行处理的过程中,常常需要底层数据库的信息,这时数据访问层便会从数据库获取相应的信息并将这些信息传送给业务逻辑层使用。

系统结构:

系统的包结构依据系统的层次结构而设计。其中pojo包主要存放系统所有的实体类,这些类与数据库中的表一一对应;controller包主要存放系统中的控制器;service包主要存放业务逻辑的接口与其实现类;dao包主要存放数据访问层的相关接口,由于一般会使用Mybatis作为系统的ORM框架,所以DAO层中接口的实现类由该框架根据Mapper包中的配置文件自动生成;前端的页面、js代码以及CSS样式等放在系统根目录下的resource包中。系统中各种包之间的调用关系如下图所示:

五.数据库的设计

在明确了系统的功能模块以及整体结构之后,就需要对系统的数据库进行设计。数据库是整个系统的根基,数据库的设计最少需要占用整个系统开发的三成以上的时间。若在确定系统需求后就想急功近利,直接进入编码阶段,最后只能是得不偿失:轻则需要对数据库进行大量修改,重则导致项目开发无法进行。在设计数据库时要遵守“三少”的原则,即在实现系统设计目标的前提下使数据库中的表、每张表中的主键数量以及每张表中的字段数量尽可能地少。这样可以避免在系统编码阶段中因数据库的修改而导致开发过程的中断,使系统的开发更加流畅。

数据库E-R图的设计:数据库的E-R图即实体-联系图,E-R图能够很好地反映出数据库中的实体、实体的属性和各实体之间的联系,是对系统数据库的总体概括。E-R图有实体、属性和关系这三个要素,分别用矩形、椭圆形和菱形来表示。

数据表的设计:根据系统功能模块的设计以及数据库的E-R图可以设计出详细的数据表。  

六.开发准备

主要介绍系统开发前所需要做的一些准备工作,包括开发工具的选择以及开发环境的搭建。

开发工具:

(1)系统一般使用sts(Spring Tool Suite)来开发,这款开发工具是在Eclipse的基础上,将Spring技术集成在其中,使用sts工具可以很大程度地减少项创建的工作量。

(2)系统开发中一般使用谷歌公司的Chrome浏览器,该浏览器具有简洁、快速和不易崩溃等特点。

(3)系统一般使用navicat作为数据库处理工具。

开发环境:

开发中将MVC模式与系统的三层结构结合起来,在三层结构的基础上融入MVC模式中的控制器,即多加入一个控制层。

控制层的作用不是处理具体的业务逻辑,而更像是一个“连接器”,将系统的表现层与业务逻辑层和数据访问层连接起来。

表现层要实现某种业务时会先向控制层发送请求,SpringMVC框架会根据请求的地址找到控制层中与该地址相映射的方法,控制层中的方法并不进行业务的处理,而是通过在其中调用业务逻辑层的方法来完成具体的业务逻辑,之后会将所有页面需要的数据信息进行“加工”和“打包”并传回页面使用。

业务逻辑层要处理具体的业务则需要对数据库进行访问,该层也不直接与数据库交互,而是通过调用数据访问层(或DAO层)接口中的具体方法,由于系统一般使用Mybatis技术,即将sql语句单独写在了xml文件中,所以系统会自动根据调用的DAO层接口的方法名寻找相应的sql语句实现对数据库的访问。

接着初始化时窗下拉菜单,采用Ajax技术:在页面的js文件中向后台发送Ajax请求;通过请求地址找到控制层中相关类的init()方法;接着调用业务逻辑层相关接口的init()抽象方法.将数据存储在数据库中,会调用了DAO层demo_timesMapper接口中的selectIsState()方法,Mybatis根据方法名在mapper包里的demo_timesMapper.xml文件中找到相应的sql语句。至此,从页面顶层到数据库底层的信息调用完成,接下来系统要做的就是将从底层数据库获得的数据逐层“加工”并返回,直到控制层将所有有用的数据传回页面,页面通过相关前端技术将所有时窗信息加载到下拉菜单中。使用Ajax技术后使得上述过程不需要经过页面的跳转,页面采用异步传输的方式获取信息。

七.学习总结:

主要介绍了开管理系统所涉及到的一些相关技术。首先对Spring Boot技术进行详细介绍;然后根据流程图简单说明了MVC模式的具体工作流程;接下来介绍了数据库相关技术,主要介绍了开发中使用到的MyBatis框架,并将该框架与其他ORM框架的工作流程进行比较,突出了使用MyBatis的好处;最后简单介绍了一些Web前端技术以及对接技术。

  • 学习心得:  

此次学习,是一个从完全没有开发概念到逐渐有了相应的理论基础的过程,是从0到1的过程,收获颇多。虽然技术方面还未进行系统的学习,只会某一模块的一丢丢,但是这为日后的开发提供了理论基础,也做好了铺垫,我也坚信未来的路途是坎坷曲折的,只有保持一颗学习的心,一种积极向上的理念,才能够拨开云雾见天日!最后也诚挚地感谢老师一个学期的辛勤讲解!

             

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/308709.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2024最新最全【学习网络安全必须知道的100 个网络基础知识】

1 什么是链接? 链接是指两个设备之间的连接。它包括用于一个设备能够与另一个设备通信的电缆类型和协议。 2 OSI 参考模型的层次是什么? OSI 七层模型:物理层,数据链路层,网络层,传输层,会话层,表示…

理解 AQS 和 ReentrantLock

其他系列文章导航 Java基础合集数据结构与算法合集 设计模式合集 多线程合集 分布式合集 ES合集 文章目录 其他系列文章导航 文章目录 前言 一、公平锁和非公平锁 1.1 含义 1.2 如何自我实现 1.2.1 公平锁实现: 1.2.2 非公平锁实现: 1.2.3 公平和非公平的区…

第十一章 浏览器对象模型(BOM)的介绍和使用

文章目录 一、BOM介绍二、window的子对象三、window的方法和事件四、定时器五、练习 一、BOM介绍 BOM是Browser Object Model的缩写,简称浏览器对象模型。这个对象就是windowBOM提供了独立于内容而与浏览器窗口进行交互的对象BOM由一系列相关的对象构成&#xff0c…

状态模式-举例

在软件系统中,有些对象也像水一样具有多种状态, 这些状态在某些情况下能够相互转换, 而且对象在不同的状态下也将具有不同的行为。 参考日志来设置状态。 如何判断一个设计模式是行为模式还是什么其他模式? 什么叫行为模式&#…

mongoose中http server服务器解决“Access-Control-Allow-Origin mongoose”跨域问题

问题 使用mongoose做http服务器,自己构造的浏览器端jquery在访问server时,会遇到: Access to XMLHttpRequest at http://127.0.0.1:8000/ from origin null has been blocked by CORS policy: No Access-Control-Allow-Origin header is pr…

rax3000m刷openwrt固件

rax3000m刷机过程(nand版本) 刷机准备文件https://www.123pan.com/s/X5m9-6Ynj.html提取码:VtBW 接线关系:路由器lan口接电脑 1.上传配置开启ssh的配置文件(登录路由器后台管理界面在找到配置管理,上传配置文件rax3…

计算机网络【DNS】

DNS 基本概述 与 HTTP、FTP 和 SMTP 一样,DNS 协议也是应用层的协议,DNS 使用客户-服务器模式运行在通信的端系统之间,在通信的端系统之间通过下面的端到端运输协议来传送 DNS 报文。但是 DNS 不是一个直接和用户打交道的应用。DNS 是为因特…

Nature Machine Intelligence 人形机器人的层次化生成建模

2023年11月2日,德国英特尔研究院,英国伦敦大学学院和美国VERSES研究实验室的研究人员在《Nature Machine Intelligence》杂志发表了一篇题为“Hierarchical generative modelling for autonomous robots”的论文。 研究内容 人类通过规划、执行和…

某后台管理系统加密参数逆向分析

前言 在我们日常的渗透中经常会遇到开局一个登录框的情况,弱口令爆破当然是我们的首选。但是有的网站会对账号密码等登录信息进行加密处理,这一步不由得阻碍了很多人的脚步。前端的加解密是比较常见的,无论是 web 后台还是小程序&#xff0c…

【音视频 ffmpeg 学习】 跑示例程序 持续更新中

环境准备 在上一篇文章 把mux.c 拷贝到main.c 中 使用 attribute(unused) 消除警告 __attribute__(unused)/** Copyright (c) 2003 Fabrice Bellard** Permission is hereby granted, free of charge, to any person obtaining a copy* of this software and associated docu…

Unity JSON编码解码之LitJson 深度剖析

把LitJson的代码库放入到项目中,如图所示:JSON在游戏开发中是一种序列化/反序列化常用的技术,把游戏相关的数据,如地图组成,通过JSON编码,序列化成JSON文本,传输或存储, 要使用的时候再通过JSON技术把文本解析成数据对象&#xff…

Python FastApi连接oracle进行查询

这边技术选型是cx_oracle进行连接查询,cx_oracle的使用首先要有官方的客户端才能连接到数据库,python并不自带客户端。我用是Python3.9 安装客户端 可以到官网在选择最新版进行下载。 Instant Client for Microsoft Windows (x64) 64-bit 或者直接从我…