当前位置:   article > 正文

三大框架SSM基础知识点_ssm框架

ssm框架

目录

1.三大框架(SSM)简述

1.1 概述

1.2 发展历程

1.3 SSM三大框架的未来

2 .前端框架SpringMVC

2.1 Spring MVC发展概述

2.2 MVC模型

2.3 工作原理

2.4 springMvc组件:

2.4 实际案例

案例1 --查询用户信息

3.整合资源框架Spring

3.1 初识Spring

3.2.Spring核心五大模块

2.面向切面编程(Aop)

3.2.2.三大核心组件的关系

3.3.两大核心

3.4 Spring框架总结

4. mybatis

4.1 Mybatis概述

4.2 内部结构图

4.3 mybatis核心

4.3 mybatis升级版MP(mybatis-plus)

# 特性

#支持数据库

# 常用功能1--CRUD:

# 常用功能2--自定义ID生成器:

5.依赖管理工具maven

5.1 应用背景

5.2.maven核心概念

1.仓库 repository

2.依赖 dependency

每个核心jar包形成一个依赖,maven底层进行它相关的jar的自动导入

5.3 maven小结

maven优点:

maven缺点:

6.springMVC整合案例

6.1.项目结构

6.2 前端代码

6.3后端代码

 6.3.1引入pom.xml文件

 6.3.2分部代码

1controller层代码

2 service层代码

3 pojo层代码

4 自启动类

5 Mapper接口及映射

6 核心配置文件

6.3.调用以及测试关系

6.4.案例总结


前言:本文是对于SSM三大框架的简单总结,涉及三大框架的主要功能和相关的一些工具,也希望此文是对于个人知识点的一个总结。


1.三大框架(SSM)简述

1.1 概述

现在流行的三大框架是指spring ,springMVC,mybatis 三层框架结合运用的一个框架,其是当前各公司开发的主流。现行的大部分项目的开发都是采用三大框架,单项目过于复杂时,springMvc中的控制层往往抽离出来,成为单独的前端访问界面,并与前端进行数据交互。

1.2 发展历程

原始时代我们用一个jsp搞定一切,但如此开发大型项目时我们遇到了问题,前端美化的代码和后端的代码交织,代码中又有html、js、css样式,又有业务逻辑和数据库访问代码,杂乱不清晰,美工和开发打架。

于是mvc分层架构封建时代出现,把我们写代码的地方硬性分成3个地方,Model层封装数据,View视图层页面展现,Controller控制层访问转发。代码之间的耦合度降低。概念有了,需要实际干活的。于是随着mvc分层概念的深入人心,业界涌现出很多实现框架,最著名的莫过于struts1和struts2。随着前端框架的成熟,后端框架也应运而生如:dbutils、jdbcTemplate、hibernate、ibatis、mybatis。前端WEB层框架有了,后端数据库层访问框架有了,那中间呢?谁来胜任?spring破石而出。

只能完成一部分工作,不能整体解决前后端的事务。spring正是抓住这点,在地位上并没有抹杀它们,而是依然给它们高官厚禄,承认它们的市场地位,还赠与一个事务管理。通过一边打压一边拉拢的方式,spring在软件开发中获得了举足轻重的地位,一个经典的三层框架诞生SSH (Strut2+Spring+Hibernate)。

spring创新的形成了一套新的理论体系,可谓前无古人后无来者。其中最核心的是:IoC控制反转、DI依赖注入、Bean工厂、SpringAOP面向切面编程、事务控制。spring在开发升级的路上也并未停止不前,而是不断更新换代,占领市场。spring占领市场后,开始对有功之臣进行清洗,struts2不再优秀,致命bug层出不穷,刚好落井下石,spring推出了springmvc,最终终结了struts2。hibernate想用jdbcTemplate和jdo替代,却被mybatis超越,目前还未统一。世界又达到新的平衡,经典的新三大框架诞生,SSM(SpringMVC+Spring+MyBatis)。

1.3 SSM三大框架的未来

2 .前端框架SpringMVC

2.1 Spring MVC发展概述

Spring MVC属于SpringFrameWork的后续产品,已经融合在Spring Web Flow里面。Spring 框架提供了构建 Web 应用程序的全功能 MVC 模块。使用 Spring 可插入的 MVC 架构,从而在使用Spring进行WEB开发时,可以选择使用Spring的SpringMVC框架或集成其他MVC开发框架,如Struts1(现在一 般不用),Struts2(一般老项目使用)等。

SpringMVC就是基于MVC设计模式来实现的。

我们的POJO就是Model层,我们的JSP就是视图层,我们的Controller就是控制层。

现在主流基于SSM三大框架开发都是在MVC上继续演化,又分为持久层DAO,业务层Service,控制层Controller。持久层用来和数据库读写ORM,业务层用来处理复杂的业务逻辑,控制层用来处理MVC的控制。

2.2 MVC模型

mvc模型用来进行分层的结构,这样代码分离结构清晰,各层代码,各司其职,易于开发大型项目。而在Springboot整合的思想中,也采用了Mvc设计模式,具体如下图:

MVC(Model模型、View视图、Control控制层),将软件进行分层达到松耦合的效果。

通用的软件编程思想, 在MVC设计模式中认为, 任何软件都可以分三层:控制层(Controller)、数据处理模型(Model)、负责展示数据的视图(View)。


2.3 工作原理

Springmvc架构原理解析

  1. 发起请求到前端控制器(DispatcherServlet)
  2. 前端控制器请求HandlerMapping查找 Handler,可以根据xml配置、注解进行查找
  3. 处理器映射器HandlerMapping向前端控制器返回Handler
  4. 前端控制器调用处理器适配器去执行Handler
  5. 处理器适配器去执行Handler
  6. Handler执行完成给适配器返回ModelAndView
  7. 处理器适配器向前端控制器返回ModelAndView,ModelAndView是springmvc框架的一个底层对象,包括 Model和view
  8. 前端控制器请求视图解析器去进行视图解析,根据逻辑视图名解析成真正的视图(jsp)
  9. 视图解析器向前端控制器返回View
  10. 前端控制器进行视图渲染,视图渲染将模型数据(在ModelAndView对象中)填充到request域
  11. 前端控制器向用户响应结果

2.4 springMvc组件:


1、前端控制器DispatcherServlet(不需要程序员开发)
作用接收请求,响应结果,相当于转发器,中央处理器。
有了DispatcherServlet减少了其它组件之间的耦合度。

2、处理器映射器HandlerMapping(不需要程序员开发)
作用:根据请求的url查找Handler

3、处理器适配器HandlerAdapter
作用:按照特定规则(HandlerAdapter要求的规则)去执行Handler

4、处理器Handler(需要程序员开发)
注意:编写Handler时按照HandlerAdapter的要求去做,这样适配器才可以去正确执行Handler

5、视图解析器View resolver(不需要程序员开发)
作用:进行视图解析,根据逻辑视图名解析成真正的视图(view)

6、视图View(需要程序员开发jsp)
View是一个接口,实现类支持不同的View类型(jsp、freemarker、pdf…)
 

2.4 实际案例

案例1 --查询用户信息

1.2结构图

 2.三层核心代码

  1. //控制层
  2. @RestController //@Controller + @ResponseBody
  3. @RequestMapping("car")
  4. public class CarController {
  5. @RequestMapping("get")
  6. public String get(){
  7. return "123";
  8. }
  9. //pojo层
  10. @Data
  11. public class Car {
  12. private int id;
  13. private String name;
  14. private String type;
  15. private String color;
  16. private double price;
  17. }
  18. //自启动类
  19. @SpringBootApplication
  20. public class RunApp {
  21. public static void main(String[] args) {
  22. SpringApplication.run(RunApp.class);
  23. }
  24. }

测试结果:

案例2:提交用户数据

3.整合资源框架Spring

3.1 初识Spring

3.2 Spring核心概念

(两大核心,三大组件,五大模块)

3.2.Spring核心五大模块

模块  说明
BeanFactory   Spring内部使用,创建bean的工厂
ApplicationContext  外部应用程序调用,也成为spring容器
IoC控制反转Inversion of Control开发者在无需自己new对象,无需关心对象的创建过程User user = new User(); 手动创建对象User user = context.getBean(user); 容器创建对象
DI依赖注入Dependency Injection松耦合方式实现对象直接的依赖
AOP面向切面编程 补充java面向对象的不足

1.模拟bean工厂

  1. public class SpringContext {//模拟Spring框架是spring的核心
  2. //1,创建容器管理bean->[user,dept,hello]
  3. //2,创建Spring容器->{hello=new Hello(),user=new User()}
  4. //3.getBean(),有就取出,没有就创建并放入容器
  5. //1,创建容器管理bean->[user,dept,hello]
  6. private List<Bean> bf=new ArrayList<>();
  7. public void SC01() throws Exception {
  8. Bean a=new Bean();
  9. a.setName("hello");//设置bean的扫描值
  10. a.setPath("cn.tedu");//设置bean的扫描路径
  11. bf.add(a);
  12. init01();
  13. }
  14. //2,创建Spring容器->{hello=new Hello(),user=new User()}
  15. private final Map<String, Object> fbo = new ConcurrentHashMap<>();//初始化bean工厂
  16. private void init01() throws Exception {
  17. for(Bean b:bf){
  18. //map里的key
  19. String key=b.getName();
  20. //反射创建对象,作为value存入map
  21. String path=b.getPath();
  22. Object value=Class.forName(path).newInstance();//反射技术,将对象的值作为其的重要依据
  23. fbo.put(key,value);
  24. }
  25. }
  26. //3.getBean()有就直接取出来,没有就创建并放入容器
  27. public Object getBean(String name){
  28. return fbo.get(name);
  29. }
  30. }

2.面向切面编程(Aop)

  1. public class Testioc {
  2. @Test
  3. public void ioc2(){
  4. //1.读取核心配置文件
  5. ClassPathXmlApplicationContext Spring02=
  6. new ClassPathXmlApplicationContext("" +
  7. "Spring-config01l.xml");
  8. //2,getBean---参数是类名,但首字母要编变成小写才行
  9. Object o=Spring02.getBean("student");
  10. System.out.println(o);
  11. Student a=(Student)o;
  12. a.get();
  13. Object o2= Spring02.getBean("studentscore");
  14. System.out.println(o2);
  15. StudentScore b=(StudentScore)o2;
  16. b.get03();
  17. StudentInfo c=(StudentInfo)Spring02.getBean("studeninfo");
  18. c.get02();
  19. }
  20. }

3.2.2.三大核心组件的关系


Bean、Context、Core三大核心组件的关系:

Bean 包装的是 Object,而 Object 必然有数据,如何给这些数据提供生存环境就是 Context要解决的问题,对 Context 来说它就是要发现每个 Bean 之间的关系,为它们建立这种关系并且要维护好这种关系。所以 Context 就是一个Bean关系的集合,这个关系集合又叫 Ioc 容器,一旦建立起这个 Ioc 容器后 Spring 就可以为你工作了。那 Core 组件又有什么用武之地呢?其实Core 就是发现、建立和维护每个 Bean 之间的关系所需要的一些类的工具,从这个角度看来,Core 这个组件叫 Util 更能让你理解。

把Bean 比作一场演出中的演员的话,那 Context 就是这场演出的舞台背景,而 Core应该就是演出的道具了。只有他们在一起才能具备能演出一场好戏的最基本的条件。当然有最基本的条件还不能使这场演出脱颖而出,还要他表演的节目足够的精彩,这些节目就是 Spring 能提供的特色功能了。

3.3.两大核心

  • IoC(Inversion of Control)简单来说就是将对象Object的创建的权力及对象的生命周期的管理过程交由Spring框架来处理,从此在开发过程中不在需要关注对象的创建和生命周期的管理,而是在需要的时候由Spring框架提供,这个由Spring框架管理对象创建和生命周期的机制称之为控制反转。
  • 在创建对象的过程中Spring可以依据对象的关系,自动把其它对象注入(无需创建对象,直接拿着使用)进来,这个过程称之为DI(Dependency Injection)依赖注入。

1 IOC(Inversion of Control),控制反转。

就是指将对象的创建,对象的存储(map),对象的管理(依赖查找,依赖注入)交给了spring容器。

具体案例:

 2 DI(Dependency Injection)依赖注入 。

相对于IoC而言,依赖注入(DI)更加准确地描述了IoC的设计理念。所谓依赖注入,即组件之间的依赖关系由容器在应用系统运行期来决定,也就是由容器动态地将某种依赖关系的目标对象实例注入到应用系统中的各个关联的组件之中。

3.4 Spring框架总结

Spring的功能核心是系统自动创建并管理对象;主要是以下两件事:

  1. 创建对象
  2. 设置对象的关联关系

4. mybatis

4.1Mybatis概述

MyBatis的前身就是iBatis,iBatis本是apache的一个开源项目,2010年5月这个项目由apahce sofeware foundation 迁移到了google code,并且改名为MyBatis。

MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架。MyBatis 消除了几乎所有的 JDBC 代码和参数的手工设置以及结果集的检索。

  1. 简化JDBC的开发
  2. 能够更好的完成ORM(对象关系映射)

4.2 内部结构图

4.3 mybatis核心

1. XML映射

1.1参数解析

a)别名:alias

在sqlMapConfig.xml配置,在映射文件中直接写对象名称即可

b)参数值:paramterType
指定参数类型,通常制定一个对象类型。

c)返回值:resultType
非常重要的东西,即完成ORM的映射关系所在。这里指定的cd.tedu.mybatis.domain.User代表把结果集转换成一个User对象实例。

d)返回值:resultMap
resultMap 用于对复杂对象结构时,对应的ResultMap结构名称

1.2动态SQL

Mybatis提供使用ognl表达式动态生成sql的功能。

sql和include:

Sql标签用来提取SQL片段,来提高SQL的复用.使用位置需要通过include引用指定的SQL片段.

if:   执行SQL时,可以添加一些判断条件.

where:去掉条件中可能多余的and或者or

foreach:用于in子查询中的多个值的遍历

4.3 mybatis升级版MP(mybatis-plus)

mybatis-plus官网:简介 | MyBatis-Plus

MyBatis-Plus (opens new window)(简称 MP)是一个 MyBatis (opens new window)的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。

# 特性

  • 无侵入:只做增强不做改变,引入它不会对现有工程产生影响,如丝般顺滑
  • 损耗小:启动即会自动注入基本 CURD,性能基本无损耗,直接面向对象操作
  • 强大的 CRUD 操作:内置通用 Mapper、通用 Service,仅仅通过少量配置即可实现单表大部分 CRUD 操作,更有强大的条件构造器,满足各类使用需求
  • 支持 Lambda 形式调用:通过 Lambda 表达式,方便的编写各类查询条件,无需再担心字段写错
  • 支持主键自动生成:支持多达 4 种主键策略(内含分布式唯一 ID 生成器 - Sequence),可自由配置,完美解决主键问题
  • 支持 ActiveRecord 模式:支持 ActiveRecord 形式调用,实体类只需继承 Model 类即可进行强大的 CRUD 操作
  • 支持自定义全局通用操作:支持全局通用方法注入( Write once, use anywhere )
  • 内置代码生成器:采用代码或者 Maven 插件可快速生成 Mapper 、 Model 、 Service 、 Controller 层代码,支持模板引擎,更有超多自定义配置等您来使用
  • 内置分页插件:基于 MyBatis 物理分页,开发者无需关心具体操作,配置好插件之后,写分页等同于普通 List 查询
  • 分页插件支持多种数据库:支持 MySQL、MariaDB、Oracle、DB2、H2、HSQL、SQLite、Postgre、SQLServer 等多种数据库
  • 内置性能分析插件:可输出 SQL 语句以及其执行时间,建议开发测试时启用该功能,能快速揪出慢查询
  • 内置全局拦截插件:提供全表 delete 、 update 操作智能分析阻断,也可自定义拦截规则,预防误操作

#支持数据库

  • MySQL,Oracle,DB2,H2,HSQL,SQLite,PostgreSQL,SQLServer,Phoenix,Gauss ,ClickHouse,Sybase,OceanBase,Firebird,Cubrid,Goldilocks,csiidb

  • 达梦数据库,虚谷数据库,人大金仓数据库,南大通用(华库)数据库,南大通用数据库,神通数据库,瀚高数据库

# 常用功能1--CRUD:

  • 通用 Service CRUD 封装IService (opens new window)接口,进一步封装 CRUD 采用 get 查询单行 remove 删除 list 查询集合 page 分页 前缀命名方式区分 Mapper 层避免混淆,
  • 泛型 T 为任意实体对象
  • 建议如果存在自定义通用 Service 方法的可能,请创建自己的 IBaseService 继承 Mybatis-Plus 提供的基类
  • 对象 Wrapper 为 条件构造器

# 常用功能2--自定义ID生成器:

自 3.3.0 开始,默认使用雪花算法+UUID(不含中划线)

自定义示例工程:

5.依赖管理工具maven

5.1 应用背景

1.企业级架构架构图

2.业务逻辑以及调用顺序

经典的业务请求过程如下:

  1. 前端html页面发起ajax请求,访问SpringMVC框架的Controller控制层,
  2. SpringMVC框架解析请求,找到要调用的某个Controller,找到其中的findAll方法,同时把请求提交的参数封装到java对象中。
  3. Controller层把请求传递给Spring框架的Service业务层,Service层在把请求传递给Mybatis框架的Mapper持久层,Mapper访问MySQL数据库进行数据库表的查询,
  4. 查询结果返回给MapperMapper再返回给Service层,Service再返回给Controller层。
  5. Controller把java数据转换为json字符串,返回给ajax调用
  6. ajax进行回调并把json字符串转换为js对象,再在页面中就可以通过js/vue解析js对象,最终把数据展现到html页面中。

调用情况如下图:

3 开发使用的工具

  • 开发工具:前端采用HBuilderX,而后端采用eclipse/idea
  • 项目管理:前端采用npm、webpack,而后端采用Maven、SpringBoot
  • web中间件:前端采用NodeJS,而后端采用Tomcat

Java工程中我们自己去找jar,或者来自官网,或者来自网友的分享,或者来自项目团队的共享,不论何种方式,都需要把jar文件复制到lib目录中,并且buildpath。

Maven改变这种手动维护jar的方式,设计出一套自动维护jar的体系,已经广泛在软件项目中使用,是软件开发人员必须掌握的技术。

5.2.maven核心概念

meven采用全新的设计体系:创先河的发明pom模型,引入了“仓库”、“依赖”、“坐标”和“命令”这四大特征,具体说明如下:


1.仓库 repository

全球仓库(中央仓库):全球开发者都可以连接它来自动下载jar包,而无需去厂家官网下载。

镜像仓库:中国就有网易、阿里等镜像仓库。

本地仓库:下载一次后,不会再次下载的,除非你删除了。
 

2.依赖 dependency


每个核心jar包形成一个依赖,maven底层进行它相关的jar的自动导入

  1. <dependency>
  2.     <groupId>mysql</groupId>
  3.     <artifactId>mysql-connector-java</artifactId>
  4.     <version>5.1.32</version>
  5. </dependency>


3.坐标 coordinate

4.命令 mvn cmd

常用命令:

  • clean 清理
  • compile 编译
  • test 测试
  • site 站点文档
  • package 打包jar、war
  • deploy 部署到私服
  • install 安装jar到本地仓库中
  • run 运行

5.3 maven小结

maven优点:

Jar管理起来更加轻松,已经被业界广泛采用,springboot就是maven的延伸
仓库的独特设计,实现仓库自行维护
依赖管理方便很多,把开发人员从手工导包解脱出来
坐标体系使不同厂商的文件也井然有序,不会冲突覆盖
生命周期对应命令,使一键做完以前手动的n步事情

maven缺点:

下载异常让初学者手足无措,不得不删掉仓库重新下就好了,为什么好了,不知道
部分包因为版本问题,需要手工导入
引发新的问题,版本冲突:大型项目中jar中依赖其它jar包,会发生你调3.1,我调3.2,臭名昭著的版本冲突问题,如何解决呢?上面方式手工排除,而maven采用就近原则
本地仓库日积月累巨大,本人的达到2g,很多低版本的jar已经无用,或者过气的技术的jar
大型项目中jar冲突非常厉害,仍需手动排除,而且实现方式很多,没有统一规则。如当年加入dubbo的jar时,那冲突叫做满天飞,项目做完也没很良好的解决。但这点springboot却解决了,maven的失败却早就了今天springboot能大行其道的根本原因。
 

6.springMVC整合案例

6.1.项目结构

1.前端是简单的网页,由直接访问请求和Post请求

 2后端结构

        在项目中搭建前端连接层  service层  controller层 pojo层 以及自启动类RunSpringboot;在后端连接数据库配置核心文件Application ,映射文件UseMapper.xml 以及映射接口;在中间整合层创建pojo层封装对象,依靠DI 以及Ioc控制对象,以及service层接受用户的请求,再在测试类中创建TestSpringboot,测试前后端的联通。

具体结构如图:

6.2 前端代码

  1. <head>
  2. <meta charset="utf-8">
  3. <title>SpringMvc</title>
  4. <script>
  5. function a(){
  6. /**请求类型:1.get 查询 2.post */
  7. let user={
  8. id:1,name:"tomact",
  9. age:18,sex:"女"
  10. }
  11. let url="http://localhost:8080/getUserBYId"
  12. $.get(url,user,function(data){
  13. console.log(data)
  14. alert(data)
  15. })
  16. }
  17. </script>
  18. <script src="./jquery-1.8.3.min.js"></script>
  19. </head>
  20. <body>
  21. <a href="#" onclick="a()">点我获取ajax</a>
  22. </body>

6.3后端代码

 6.3.1引入pom.xml文件

 6.3.2分部代码

1controller层代码

  1. @RestController //控制请求
  2. @CrossOrigin //跨域
  3. public class UserController {
  4. @Autowired //依赖注入
  5. private UserService userService;
  6. /**需求:查询全部用户信息
  7. * URL:/getAll
  8. * 返回值:List<User>*/
  9. @RequestMapping("/getAll") //控制参数
  10. public List<User> getAll(){
  11. return userService.getAll();
  12. }

2 service层代码

  1. @Service//服务层
  2. @Repository//@Mapper //MapperScan
  3. public class UserServiceImp implements UserService{
  4. @Autowired //依赖注入
  5. private UserMapper userMapper;
  6. @Override
  7. public List<User> getAll(){
  8. //重写方法
  9. return userMapper.selectList(null);
  10. }
  11. 接口
  12. @Service
  13. public interface UserService {
  14. List<User> getAll();

3 pojo层代码

  1. /**独享关系映射配置:
  2. * 1.User对象需要与demo_user表绑定
  3. * 2.User对象中的属性与表中的字段一一绑定
  4. * */
  5. @Data //get set toString
  6. @Accessors(chain = true) //链式编程
  7. @TableName("demo_user")
  8. public class User implements Serializable {
  9. @TableId(type=IdType.AUTO)//id 代表主键
  10. //拓展:uuid
  11. //主键自增
  12. private Integer id;
  13. //@TableField("name")
  14. //如果属性与字段同名(包括驼峰规则) 注解可以省略
  15. private String name;
  16. private Integer age;
  17. private String sex;
  18. }

4 自启动类

  1. @SpringBootApplication
  2. @MapperScan("com.jt.mapper" ) //开启扫描功能
  3. public class RunSpringBoot {
  4. public static void main(String[] args) {
  5. SpringApplication.run(RunSpringBoot.class,args);
  6. }
  7. }

5 Mapper接口及映射

接口

  1. @Component
  2. //注意事项:继承接口时,必须添加泛型对象,否则映射表报错
  3. public interface UserMapper extends BaseMapper<User>{
  4. //Mp规则: 对象的方式操作数据库 curd操作
  5. List<User> getAll();

映射文件

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE mapper
  3. PUBLIC "-//mybatis.org//DTD mapper 3.0//EN"
  4. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  5. <!--规则: namespace必须与接口一一对应 -->
  6. <mapper namespace="com.jt.mapper.UserMapper">
  7. <!--驼峰命名规则
  8. 表字段: user_id,user_name
  9. 对象的属性: userId,userName
  10. resultType: 保证属性与字段名称必须一致.
  11. Mybatis提供了驼峰命名规则:
  12. 规则: 字段user_id~~~去除_线~~~之后映射对象的属性userId-->
  13. <select id="getAll" resultType="User">
  14. select * from demo_user
  15. </select>
  16. </mapper>

6 核心配置文件

  1. spring:
  2. datasource:
  3. driver-class-name: com.mysql.cj.jdbc.Driver 设置数据库连接
  4. url: jdbc:mysql://127.0.0.1:3306/jt?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf8&autoReconnect=true&allowM
  5. ultiQueries=true 连接数据库
  6. username: root 用户名
  7. password: lydon 密码
  8. #SpringBoot整合mp配置
  9. mybatis-plus:
  10. type-aliases-package: com.jt.pojo
  11. mapper-locations: classpath:/mybatis/*.xml
  12. #开启驼峰映射
  13. configuration:
  14. map-underscore-to-camel-case: true
  15. #不打印日志
  16. ##debug: false
  17. #Mapper接口执行 打印Sql日志
  18. logging:
  19. level:
  20. com.jt.mapper: debug

6.3.调用以及测试关系

在前后端交互过程中,springboot整合了三大框架,用户在页面发送请求,请求首先传递到控制层,控制层继续传递数据给业务层,业务层经过一定的处理,继续将数据传递给下一层,最后在持久层执行数据的操作。在数据库得到对对应的数据后,又返回传递给前端,显示在网络的页面上。

 springMvc交互过程

前端发送ajax请求,将请求传递给控制层。控制层通过@RestController实现java与we的连接,再通过@CrossOrigin//实现跨域,再通过扫描请求头,在网页中输入相应网址即可访问java程序端

具体如下图

6.4.案例总结

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Gausst松鼠会/article/detail/239689
推荐阅读
相关标签
  

闽ICP备14008679号