Springboot所有集合+三大框架+MyBatisPlus

本文详细介绍了SpringBoot的配置、热部署、日志修改及YML文件的使用,包括数据库连接配置、@Data注解解释、自动装配原理。同时,讲解了SpringMVC中HTTP状态码的含义,如100、200、301、400和500等,并举例说明了@RequestBody注解的用途。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

---------------SpringBoot--------------------

注释 todo

在这里插入图片描述

application.yaml

数据库配置

spring:
  datasource:
    url: jdbc:mysql://127.0.0.1:3306/heima?useSSL=false
    username: root
    password: 123456
    driver-class-name: com.mysql.cj.jdbc.Driver

配置

配置热部署

第一步 导热部署的坐标


<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-devtools</artifactId>
    <scope>runtime</scope>
    <optional>true</optional>
</dependency>

第二步 增加插件

下段配置我们粘贴进聚合父类总工程的pom.xml里
 
<build>
    <finalName>你自己的工程名字</finalName>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
            <configuration>
                <fork>true</fork>
                <addResources>true</addResources>
            </configuration>
        </plugin>
    </plugins>
</build>

第三步 修改设置
在这里插入图片描述

第四步 快捷键 ctrl+shift+Alt+/ 选择registry
在这里插入图片描述

第五步 重启IDEA
启动时可能会出现的报错 ------不用管他
在这里插入图片描述

1数据库文件 变成灰色 解决办法 将resource文件夹 进行标记

在这里插入图片描述

解决问题
在这里插入图片描述

项目启动前就配置maven的位置

在这里插入图片描述

技巧

Springboot如何看编译后的代码

maven 工具的compile 然后去看target文件
在这里插入图片描述
在这里插入图片描述

注解意思

@Data

lombok中的 data 注解相当于 Get Set EqualsAndHashCode
没有包括 NoArgsConstructor AllArgConstructor 这两个注解
在这里插入图片描述

SpringBoot中的application.yml

表示数组

springboot 中的maven

maven package

在这里插入图片描述

maven clean targert文件会消失

在这里插入图片描述

如何使打包的时候不进行测试

在这里插入图片描述

黑马springboot

springboot Restful 风格

风格介绍
在这里插入图片描述

案例
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
总结
在这里插入图片描述在这里插入图片描述
在这里插入图片描述在这里插入图片描述在这里插入图片描述
简化
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

修改控制台输出的spring图标

在这里插入图片描述

修改控制台的打印信息

在这里插入图片描述

yml文件

一对多 用- 表示
在这里插入图片描述

SpringBoot 临时属性

方式一
在这里插入图片描述
方式二
在这里插入图片描述

Springboot中出现配置文件中的配置出问题怎么解决

@Value(“${}”) 将值取出来,看是不是想要的值

***SpringBoot 报错

抽取相同模板组成一个模块的坐标导入

在这里插入图片描述

pom 文件中的注解格式

springboot报错当中测试类

测试类@Test的包导错了

爆错信息: org.junit.runners.model.InvalidTestClassError: Invalid test class ‘com.atshenzhou.TestTimeStamp’:
InvalidTestClassError无效测试类错误

修改方法 @Test 的导包错误 org.junit.Test
在这里插入图片描述

SpringBoot复制工程

第一步 复制工程
在这里插入图片描述
第二步 修改pom文件中的artifactId
在这里插入图片描述
在这里插入图片描述

第三步删除 target文件
在这里插入图片描述
第四步 删除IDEA 自动生成的文件
在这里插入图片描述
第五步 在idea 中引入
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

黑马springboot原理篇

加载bean的方式

加载bean的方式1

相关xmlApplication(xmlName)
在这里插入图片描述

加载bean的方式2

在这里插入图片描述
在这里插入图片描述

加载bean的方式3

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
@Configuration 这个注解默认代表了加载的是同一个对象
在这里插入图片描述

加载bean的方式4

在这里插入图片描述
在这里插入图片描述

加载bean的方式5

在这里插入图片描述

在这里插入图片描述

加载bean的方式6

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

加载bean的方式7

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

加载bean的方式8

spring挥舞它仲裁者的大刀来了一个致命一击,都别哔哔了,我说了算,BeanDefinitionRegistryPostProcessor,看名字知道,BeanDefinition意思是bean定义,Registry注册的意思,Post后置,Processor处理器,全称bean定义后处理器,干啥的?在所有bean注册都折腾完后,它把最后一道关,说白了,它说了算,这下消停了,它是最后一个运行的。

在这里插入图片描述

springboot面试题

自动装配

@import 注解
@import中的value 如果有类名.class可以直接将类加载,如果类名.class的类继承了ImportSelector接口会重写selectImports() 方法,方法返回的是一个字符串数组,数组里面是全限制性类名,根据全限制性类名可以得到响应的类
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

SPI service Provider Interface

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
MyAppConfig 中有一个ComponentScan的注解,注解扫描了包下面的添加了注解的类
在这里插入图片描述
MyAppConfig 中有一个ComponentScan的注解,注解扫描了包下面的添加了注解的类,
扫面的组件中一个类有@Configuration注解还有一个@MyEnableAutoImportBeans(),
@MyEnableAutoImportBeans()注解中有一个@Import注解,
@import注解中的value 有一个MyAutofigurationRegistrar.class,MyAutofigurationRegistrar.class 实现了importBeanDefinitionRegistrar和BeanClassLoaderAware两个接口,

BeanClassLoaderAware接口中有一个setBeanClassLoader的方法,重写此方法可以得到类加载器。

importBeanDefinitionRegistrar接口中重写的方法RegisterBeanDefinitions方法,方法中通过SpringFacteriesLoader.LoadFactoryNames()方法通过类加载器加载配置文件中spring.factories中的信息,信息里面通过键值对一对多的关系加载类的全限制类名,加载Bean。
在这里插入图片描述
在这里插入图片描述

SpringBoot 条件注解

在这里插入图片描述
在这里插入图片描述

SpringBoot 读取yml文件的注解

在这里插入图片描述

---------------/ SpringBoot-------------------

---------------SpringMVC--------------------

接受前端参数

在这里插入图片描述

前端响应报错码

1开头的http状态码

表示临时响应并需要请求者继续执行操作的状态代码。

100 (继续) 请求者应当继续提出请求。 服务器返回此代码表示已收到请求的第一部分,正在等待其余部分。
101 (切换协议) 请求者已要求服务器切换协议,服务器已确认并准备切换。

2开头的http状态码

表示请求成功

200 成功处理了请求,一般情况下都是返回此状态码;
201 请求成功并且服务器创建了新的资源。
202 接受请求但没创建资源;
203 返回另一资源的请求;
204 服务器成功处理了请求,但没有返回任何内容;
205 服务器成功处理了请求,但没有返回任何内容;
206 处理部分请求;

3xx (重定向)

重定向代码,也是常见的代码

300 (多种选择) 针对请求,服务器可执行多种操作。 服务器可根据请求者 (user agent) 选择一项操作,或提供操作列表供请求者选择。
301 (永久移动) 请求的网页已永久移动到新位置。 服务器返回此响应(对 GET 或 HEAD 请求的响应)时,会自动将请求者转到新位置。
302 (临时移动) 服务器目前从不同位置的网页响应请求,但请求者应继续使用原有位置来进行以后的请求。
303 (查看其他位置) 请求者应当对不同的位置使用单独的 GET 请求来检索响应时,服务器返回此代码。
304 (未修改) 自从上次请求后,请求的网页未修改过。 服务器返回此响应时,不会返回网页内容。
305 (使用代理) 请求者只能使用代理访问请求的网页。 如果服务器返回此响应,还表示请求者应使用代理。
307 (临时重定向) 服务器目前从不同位置的网页响应请求,但请求者应继续使用原有位置来进行以后的请求。

4开头的http状态码表示请求出错

400 服务器不理解请求的语法。

400 是 HTTP 的状态码,主要有两种形式:
1)bad request 意思是 “错误的请求”。
2)invalid hostname 意思是 “不存在的域名”。
原因:前端提交的字段名称或者字段类型和后台的实体类不一样,或者前端提交的参数跟后台需要的参数个数不一致,导致无法封装。
400-参数与控制器层所需要的参数不符合,并没有进入后台服务器(控制器)里。
400:说明此请求还未执行controller层,原因大多是传递参数与接收参数中有类型不一致或字段不匹配造成的

401 请求要求身份验证。 对于需要登录的网页,服务器可能返回此响应。
403 服务器拒绝请求。

404 服务器找不到请求的网页。
404-服务器无法根据客户端的请求找到资源(网页)
原因:前端调用的URL不存在

405 禁用请求中指定的方法。 方法不对 get post put delete
406 无法使用请求的内容特性响应请求的网页。
407 此状态代码与 401类似,但指定请求者应当授权使用代理。
408 服务器等候请求时发生超时。
409 服务器在完成请求时发生冲突。 服务器必须在响应中包含有关冲突的信息。
410 如果请求的资源已永久删除,服务器就会返回此响应。
411 服务器不接受不含有效内容长度标头字段的请求。
412 服务器未满足请求者在请求中设置的其中一个前提条件。
413 服务器无法处理请求,因为请求实体过大,超出服务器的处理能力。
414 请求的 URI(通常为网址)过长,服务器无法处理。
415 请求的格式不受请求页面的支持。
416 如果页面无法提供请求的范围,则服务器会返回此状态代码。
417 服务器未满足”期望”请求标头字段的要求。

5开头状态码并不常见,但是我们应该知道

500 (服务器内部错误) 服务器遇到错误,无法完成请求。
500-服务器内部错误,无法完成请求
原因:500错误是传入的参数在业务处理中出现了异常。
500-传入的参数在业务处理中出现了异常,进入了后台服务器(控制器)里。

501 (尚未实施) 服务器不具备完成请求的功能。 例如,服务器无法识别请求方法时可能会返回此代码。
502 (错误网关) 服务器作为网关或代理,从上游服务器收到无效响应。
503 (服务不可用) 服务器目前无法使用(由于超载或停机维护)。 通常,这只是暂时状态。
504 (网关超时) 服务器作为网关或代理,但是没有及时从上游服务器收到请求。
505 (HTTP 版本不受支持) 服务器不支持请求中所用的 HTTP 协议版本。

注解全部

@RequestBody

位置 是在 Controller 层的方法参数中,后面跟的是一个实体类
作用 前端传来的数据 ,根据名字与类的属性匹配 ,名字和属性必须一致,不然是空值
@RequestBody的作用其实是将json格式的数据转为java对象。

代码演示
前端

{
    "key": "搜索关键字",
    "page": 1,
    "size": 3,
    "sortBy": "default"
}

后端
pojo

@Data
public class RequestParams {
    private String key;
    private Integer page;
    private Integer size;
    private String sortBy;
}

controller

@RestController
@RequestMapping("/hotel")
public class HotelController {

    @Autowired
    private IHotelService hotelService;
	// 搜索酒店数据
    @PostMapping("/list")
    public PageResult search(@RequestBody RequestParams params){
        return hotelService.search(params);
    }
}

---------------/ SpringMVC-------------------

---------------Spring----------------------------

springIOC springAOP
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

---------------/ Spring-------------------------

---------------MyBatis----------------------------

---------------/ MyBatis-------------------------

---------------MyBatisPlus----------------------------

---------------/ MyBatisPlus-------------------------

### Spring Boot MyBatis Plus Vue 分页 实现 教程 示例 #### 配置分页插件 为了在Spring Boot项目中使用MyBatis-Plus实现分页功能,需先配置`PaginationInterceptor`拦截器。通过创建一个名为`MybatisPlusConfig`的类来完成此工作,在该类中标记有@Configuration注解用于指示这是一个配置文件,并且定义了一个方法返回一个新的`MybatisPlusInterceptor`实例[^4]。 ```java import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor; import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class MybatisPlusConfig { @Bean public MybatisPlusInterceptor mybatisPlusInterceptor() { MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor(); // 设置数据库类型为MySQL interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL)); return interceptor; } } ``` #### 创建实体类和服务层接口 接着要设计数据模型以及对应的服务层逻辑处理程序。假设有一个简单的用户表结构,则可建立相应的Java Bean表示这个表格中的记录;同时还需要编写对应的Mapper映射接口继承自BaseMapper泛型基类以便能够自动获得CRUD能力[^2]。 ```java // User.java - Entity Class @Data @NoArgsConstructor @AllArgsConstructor @TableName("users") public class User implements Serializable { private Long id; private String name; private Integer age; } // IUserService.java - Service Interface extending IService<User> public interface IUserService extends IService<User> {} ``` #### 编写前端页面请求API 最后一步是在Vue.js应用程序内发起HTTP GET/POST调用来获取经过分页后的列表项集合。通常情况下会利用axios库发送异步AJAX呼叫至后端RESTful API服务地址上携带必要的参数比如当前页码(pageNum)和每页显示条目数量(pageSize)。 ```javascript const instance = axios.create({ baseURL: 'http://localhost:8080/api/v1/users', }); async function fetchUsers({ pageNum, pageSize }) { try { const response = await instance.get(`?pageNum=${pageNum}&pageSize=${pageSize}`); console.log(response.data); } catch (error) { console.error(error.message); } } ``` 以上就是如何在一个基于Spring Boot框架构建的应用程序里面集成MyBatis-Plus组件从而简化持久化层开发流程的同时支持高效的数据检索方式——即分页查询操作的具体实践指南。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值