SpringBoot1~~~

目录

快速入门

依赖管理和自动配置

修改自动仲裁/默认版本号

starter场景启动器

自动配置

修改默认扫描包结构

修改默认配置

读取application.properties文件

按需加载原则

容器功能

@Configuration

@Import

​编辑

@Conditional

@ImportResource

配置绑定@ConfigurationProperties

Lombok

yaml

基本语法

数据类型

应用

细节

静态资源访问

Rest风格请求处理

接收参数相关注解

@PathVariable、@RequestParam

@RequestHeader

@CookieValue

@RequestBody

@RequestAttribute、@SessionAttribute

复杂参数

自定义对象参数-自动封装

自定义转换器

实现接口形式

向容器注入Bean形式                              

处理Json

内容协商

Thymeleaf

拦截器

实现接口形式

向容器注入Bean形式

文件上传

第一种

第二种 


快速入门

jdk8+,maven3.5+

    <!--导入springboot父工程--><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.5.3</version></parent><!--导入web项目场景启动器:会自动导入和web开发相关的所有依赖--><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency></dependencies>
//表示这是一个springboot应用/项目
@SpringBootApplication
public class MainApp {public static void main(String[] args) {SpringApplication.run(MainApp.class,args);//或者ConfigurableApplicationContext ioc= SpringApplication.run(MainApp.class, args);}
}
@Controller
public class HelloController {@RequestMapping("/hello")@ResponseBodypublic String hello() {return "hello";}
}

依赖管理和自动配置

修改自动仲裁/默认版本号

spring-boot-starter-parent 还有父项目, 声明了开发中常用的依赖的版本号,并且进行 自动版本仲裁 , 即如果程序员没有指定某个依赖jar的版本,则以父项目指 定的版本为准

在pom.xml修改版本号

starter场景启动器

开发中我们引入了相关场景的starter,这个场景中所有的相关依赖都引入进来了
比如我们做web开发引入了,该starter将导入与web开发相关的所有包

    <!--导入web项目场景启动器:会自动导入和web开发相关的所有依赖--><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency></dependencies>

依赖树:可以看到spring-boot-starter-web ,帮我们引入了spring-webmvc,spring-web 开发模块,还引入了spring-boot-starter-tomcat 场景,spring-boot-starter-json 场景,这些场景下面又引入了一大堆相关的包,这些依赖项可以快速启动和运行一个项目,提高开发效率

所有场景启动器最基本的依赖就是spring-boot-starter,这个依赖也就是SpringBoot自动配置的核心依赖

官方/第三方strater

自动配置

扫描包默认主程序(MainApp)所在的包及其子包下会被扫描

修改默认扫描包结构

scanBasePackages指定扫描的包,com.edu这个包及子包会被扫描

@SpringBootApplication(scanBasePackages = {"com.edu","aa.bb"}) 
public class MainApp {public static void main(String[] args) {SpringApplication.run(MainApp.class,args);}
}

修改默认配置

1、在resources目录下创建application.properties文件,更改value
2、在application.properties文件中自定义配置,通过@Value("${}")获取对应属性值

读取application.properties文件

也可以放在resource目录下的config目录下、项目路径下

public class ConfigFileApplicationListener {private static final String DEFAULT_SEARCH_LOCATIONS = "classpath:/,classpath:/config/,file:./,file:./config/*/,file:./config/";private static final String DEFAULT_NAMES = "application";
}

按需加载原则

自动配置遵守按需加载原则:引入了哪个场景starter就会加载该场景关联的jar 包,没有引入的starter 则不会加载其关联jar

SpringBoot 所有的配置功能都在spring-boot-autoconfigure 包里面

容器功能

Sping注入组件的注解仍可以在SpringBoot使用

@Configuration

传统:通过配置文件注入组件

 

使用@Configuration添加/注入组件,创建配置类来注入组件

前提:在springboot扫描的包/子包下会注入到容器
    1. @Configuration 标识这是一个配置类, 等价于配置文件
    2. 可以通过@Bean 注解注入bean对象到容器

    3.当一个类被@Configuration标识,该类-Bean也会注入容器,可以被获取

@Configuration
public class BeanConfig {//name的值指定bean的id,不指定id就是方法名@Bean(name = "monster")public Monster monster01() {return new Monster(200,"tom",18,"dance");}
}

SpringBoot2 新增特性: proxyBeanMethods 指定 Full 模式 和 Lite模式

proxyBeanMethods:代理bean的方法

(1) Full(proxyBeanMethods = true)(默认)【保证每个@Bean 方法被调用多少次返回的组件都是单实例的, 是代理方式】

(2) Lite(proxyBeanMethods = false)【每个@Bean 方法被调用多少次返回的组件都是新创 建的, 是非代理方式】

(3) 特别说明: proxyBeanMethods 是在调用@Bean方法才生效,因此,需要先获取 BeanConfig 组件,再调用方法;而不是直接通过 SpringBoot 主程序得到的容器来获取 bean, 注意观察直接通过 ioc.getBean() 获取 Bean, proxyBeanMethods 值并没有生效

(4) 如何选择: 组件依赖必须使用Full模式,如果不需要组件依赖使用Lite模式

(5) Lite模式也称为轻量级模式,因为不检测依赖关系,运行速度快

 

容器只有一个,配置类可以有多个, 就和Spring可以有多个ioc配置文件是一个道理

@Import

使用@Configuration可以将Bean注入到容器

也可以在配置类上使用@Import,就不必写具体的方法
默认id就是对应类型的全类名

@Conditional

条件装配:满足Conditional指定的条件,则进行组件注入
@Conditional 是一个根注解,下面有很多扩展注解

如果扩展注解放在配置类上,表示该类的所有组件都要进行条件约束

@ImportResource

作用:原生配置文件引入, 也就是可以直接导入Spring 传统的 beans.xml ,可以认为是SpringBoot 对Spring 容器文件的兼容

将beans.xml文件导入到配置类中

spring或springboot扫描beans.xml文件需要new ClassPathXmlApplicationContext(“”);

现在导入到配置类中,springboot可以直接SpringApplication.run(MainApp.class, args);

@Configuration
@ImportResource(locations = "classpath:beans.xml")
public class BeanConfig2 {}

配置绑定@ConfigurationProperties

加入configuration-processor依赖

        <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-configuration-processor</artifactId><!--配置optional为true说明: 表示防止将此依赖传递到其它模块--><optional>true</optional></dependency>

使用Java读取到SpringBoot 核心配置文件 application.properties 的内容, 并且把它封装到JavaBean中 

如果不添加@Component注解会报错

第二种方法在配置类上加@EnableConfigurationProperites,通过配置类注入到容器

开启Furn配置绑定功能,把Furn组件自动注册到容器中

在Bean中必须要有set方法,否则属性值是null

如果application.properties有中文,需要转成unicode编码写入

在网站中把中文转码,再粘贴回去

Lombok

写@AllArgsConstructor会覆盖无参构造器,搭配上@NoArgsConstructor

@Slf4j --- 日志输出

yaml

以数据为中心的标记语言

基本语法

数据类型

字面量

单个的、不可再分的值:data、boolean、string、number、null

对象

键值对的集合:map、hash、set、object

数组

一组按次序排列的值:array、list、queue

应用

前缀就是yaml第一级的名称

细节

如果 application.properties 和 application.yml 有 相同的前缀值绑定

application.properties 优先级高, 开发时,应当避免

加入依赖会有提示字段

        <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-configuration-processor</artifactId><!--配置optional为true说明: 表示防止将此依赖传递到其它模块--><optional>true</optional></dependency>

静态资源访问

可以直接访问x.jpg,直接放在resources下访问会报错

静态资源访问原理原理:http://localhost:8080/1.jpg,静态映射是/**,先看/1.jpg是否会被Controller处理,否则交给静态资源处理,如果静态资源找不到则响应404 页面

静态资源访问前缀和控制器请求路径冲突,需要改变静态资源访问前缀

在application.yml修改

spring:web:resources:static-locations: /res/**

改变默认的静态资源路径,比如希望在类路径下增加 hspimg目录作为静态资源路径

如果你配置static-locations,原来的访问路径就被覆盖了,需要重新指定一下

spring:mvc:static-path-pattern: /res/**web:resources:static-locations: ["classpath:/hspimg/","classpath:/META-INF/resources/", "classpath:/resources/", "classpath:/static/", "classpath:/public/"]

Rest风格请求处理

Rest 风格支持(使用HTTP请求方式动词来表示对资源的操作)

请求方式:/monster

GET-获取怪物

DELETE-删除怪物

PUT-修改怪物

POST-保存妖怪

 细节

1、客户端是PostMan 可以直接发送Put、delete等方式请求,可不设置Filter

2、如果要SpringBoot支持页面表单的Rest功能, 则需要注意如下细节

        需要在application.yml 启用filter功能,否则无效

        Rest风格请求核心Filter ; HiddenHttpMethodFilter ,表单请求会被 HiddenHttpMethodFilter 拦截 , 获取到表单 _method 的值,再判断是PUT/DELETE/PATCH

spring:mvc:hiddenmethod:filter:enabled: true

 

没有视图解析器,会输出abc,否则就走视图解析器定位的页面

        使用@Controller
        return "xxx"; 

        1、先看Controller有没有对应的[没有配置视图解析器]

        2、如果配置视图解析器,就定位页面

1、页面在静态目录下

spring:view:suffix: .htmlprefix: /

2、更改静态资源访问路径,view需要和static-path-pattern保持一致

spring:mvc:static-path-pattern: /res/**view:suffix: .htmlprefix: /res/

接收参数相关注解

@PathVariable、@RequestParam

在形参加上@PathVariable Map<String,String> map,可以把所有参数放进Map中,但是有多个值(List)只会取第一个,因为Map的key是唯一的

<a href="/monster/200/jack">@PathVariable-路径变量 monster/200/jack</a>

 =========================================================================

@RequestHeader

获取 Http 请求头 

@RequestHeader里的参数名不区分大小写
可以通过Map获取所有Http请求头

@CookieValue

获取Cookie,还可以通过request

1. value = "cookie_key" 表示接收名字为 cookie_key的cookie
2. 如果浏览器携带来对应的cookie , 那么 后面的参数是String ,则接收到的是对应的value
3. 后面的参数是Cookie ,则接收到的是封装好的对应的cookie

@RequestBody

处理Json数据

获取POST请求体

也可以封装到JavaBean对象中

输入hspedu 100,输出

@RequestAttribute、@SessionAttribute

获取域的数据

复杂参数

 

自定义对象参数-自动封装

会自动封装,要求提交的数据,表单请求参数名和对象的字段名保持一致

 

自定义转换器

SpringBoot在响应客户端请求时,将提交的数据封装成对象时,使用了内置的转换器(有124个

实现接口形式

向容器注入Bean形式                              

Converter 转换器接口

1、新建一个配置类,使用Lite模式

2、注入Bean(返回类型是接口类型WebMvcConfigurer)

     2.1.返回这个类型的对象并重写addFormatters方法,并自定义转换器

     2.2.使用匿名内部类,实现接口的方法(转换器会注册到converters容器中

换种写法,先创建自定义的转换器

如果添加了多个Converter<String,Car>类型的转换器,Hashmap的key是唯一的

后面的会覆盖前面的

处理Json

SpringBoot支持返回Json格式数据,在启用Web开发场景时,已经引入了相关依赖

会先经过return monster;再经过转换器

底层仍然使用转换器,根据请求带来的Accept类型,发出请求时就已经指定了返回的格式

内容协商

可以手动设置Accept=application/json或application/xml等等(在postman可以设置

默认按照Json格式返回,springboot 依赖包含了 json 数据格式的 jar 依赖。

可以在pox.xml中引入xml依赖,由于xml比json优先级高,会显示xml 格式的数据类型

对于浏览器,我们无法修改Accept的值 
需要开启支持基于请求参数的内容协商功能(在application.yaml中设置)

在地址后加上?format=xxx ,xxx 就是要转换显示为xxx格式的数据的值

format可以修改

Thymeleaf

服务器渲染技术,页面数据是在服务端进行渲染的,并不是前后端分离

首先要声明名称空间:xmlns:th="http://www.thymeleaf.org"

引入Thymeleaf依赖,项目会自动完成配置 

会直接使用视图解析到thymeleaf下的模板文件

拦截器

使用了Thymeleaf

与转换器写法差不多

1、实现HandlerInterceptor接口  

2、拦截器注册到配置类中(实现WebMvcConfigurer的addInterceptors)

3、指定拦截规则

实现接口形式

/images/**是静态资源的图片,也会发出请求,需要放行

向容器注入Bean形式

文件上传

使用了Thymeleaf

设置上传文件大小

第一种

第二种 

文件名:随机数+毫秒数+实际文件名

分目录存放:根据当前日期存放

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

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

相关文章

要在 Git Bash 中使用 `tree` 命令,下载并手动安装 `tree`。

0、git bash 安装 git(安装,常用命令,分支操作,gitee,IDEA集成git,IDEA集成gitee,IDEA集成github,远程仓库操作) 1、下载并手动安装 tree 下载 tree.exe 从 tree for Windows 官方站点 下载 tree 的 Windows 可执行文件。tree for Window&#xff1a;https://gnuwin32.source…

鸿蒙应用开发:全面认识鸿蒙系统

前言 随着智能设备的普及和物联网的发展&#xff0c;对操作系统的需求也越来越多样化。鸿蒙操作系统作为一款面向全场景的分布式操作系统&#xff0c;其适用范围非常广泛&#xff0c;从智能手机到家用电器&#xff0c;再到工业设备&#xff0c;都能找到应用场景。特别是在智能…

Nginx如何配置Gzip

Nginx 配置 Gzip 压缩可以显著减小传输的文件大小&#xff0c;提高网页加载速度。以下是在 Nginx 中配置 Gzip 的详细步骤&#xff1a; 一、找到 Nginx 配置文件 Nginx 的配置文件通常位于 /etc/nginx/nginx.conf 或 /usr/local/nginx/conf/nginx.conf&#xff08;取决于 Ngin…

鸿蒙网络编程系列22-Web组件文件上传示例

1. web组件文件上传功能简介 鸿蒙的web组件可以加载网页&#xff0c;如果网页本身具备文件上传功能的话就比较尴尬了&#xff0c;因为html上传文件时&#xff0c;允许用户选择本地文件&#xff0c;但是鸿蒙因为安全性的考虑&#xff0c;只允许操作沙箱中的文件&#xff0c;所以…

物联网的应用以及优势

物联网智能项目涵盖了多个行业领域&#xff0c;随着技术的不断进步和普及&#xff0c;越来越多的应用案例成为主流趋势。此篇文章将概述一些主要的物联网智能项目类别及其优势和日常使用场景&#xff1a; 主流物联网智能项目 1. 智能家居: •优势: 提升居住体验&#xff0c;…

双十一母婴有什么好物推荐?双十一这五款母婴好物不容错过!

随着双十一购物狂欢节的来临&#xff0c;母婴用品市场再次迎来了消费者的热切关注。作为家长们为孩子和自身挑选必需品的重要时刻&#xff0c;母婴用品的质量和安全性无疑成为了关注的焦点。在众多品牌和商品中&#xff0c;我们精心筛选了本年度最受欢迎的母婴用品&#xff0c;…

24/10/14 算法笔记 循环神经网络RNN

RNN: 一种专门用于处理序列数据的神经网络&#xff0c;它能够捕捉时间序列中的动态特征。RNN的核心特点是其循环连接&#xff0c;这允许网络在不同时间步之间传递信息&#xff0c;从而实现对序列数据的记忆和处理能力。 应用的场景&#xff1a; 自然语言处理&#xff08;NLP&…

关于Python AI 编程助手Fitten Code的应用体验以及Python 修改删除 sys.path 路径以实现两个项目代码的合并

一、关于Python AI 编程助手Fitten Code的应用体验 AI现在无孔不入&#xff0c;现在都开始进入到编程中了&#xff0c;有一个能适用多种编译器环境的AI编程插件 Fitten Code。其适配了 Viusal Studio&#xff0c;VS Code(本文使用)&#xff0c;JetBrains 系列(本文使用)以及Vim…

如何使用C#实现Padim算法的训练和推理

目录 说明 项目背景 算法实现 预处理模块——图像预处理 主要模块——训练&#xff1a;Resnet层信息提取 主要模块——信息处理&#xff0c;计算Anomaly Map 主要模块——评估 主要模块——评估&#xff1a;门限值的确定 主要模块——推理 写在最后 项目下载链接 说…

进入 Searing-66 火焰星球:第一周游戏指南

Alpha 第四季已开启&#xff0c;穿越火焰星球 Searing-66&#xff0c;带你开启火热征程。准备好勇闯炙热的沙漠&#xff0c;那里有无情的高温和无情的挑战在等待着你。从高风险的烹饪对决到炙热的冒险&#xff0c;Searing-66 将把你的耐力推向极限。带上充足的水&#xff0c;天…

Java线程的状态以及转换条件,与操作系统线程状态的区别?

先看图增加点记忆。 Java线程状态&#xff1a; 线程状态转换图&#xff1a; 背景知识 JAVA的线程模型与操作系统线程的对应关系是1:1的&#xff0c;线程的调度权是由操作系统控制的。 为什么java的线程状态与操作系统不一致&#xff1f; JVM线程状态&#xff1a;RUNNAB…

【含开题报告+文档+PPT+源码】基于SSM的景行天下旅游网站的设计与实现

开题报告 随着互联网的快速发展&#xff0c;旅游业也逐渐进入了数字化时代。作为一个旅游目的地&#xff0c;云浮市意识到了互联网在促进旅游业发展方面的巨大潜力。为了更好地推广云浮的旅游资源&#xff0c;提高旅游服务质量&#xff0c;云浮市决定开发一个专门的旅游网站。…

【红日安全】vulnstack (一)

&#x1f3d8;️个人主页&#xff1a; 点燃银河尽头的篝火(●’◡’●) 如果文章有帮到你的话记得点赞&#x1f44d;收藏&#x1f497;支持一下哦 【红日安全】vulnstack &#xff08;一&#xff09; 靶场搭建靶场渗透明确目标信息收集phpadmin后台getshell 靶场搭建 靶场下载…

IP报文格式、IPv6概述

IPv4报文格式 IPv4报文首部长度至少为20字节(没有可选字段和填充的情况下)&#xff0c;下面来逐一介绍首部各个字段的含义 Version版本&#xff1a;表示采用哪一种具体的IP协议&#xff0c;对于IPv4来说该字段就填充4以表示&#xff0c;如果是IPv6就填充6IHL首部长度&#xff…

网络资源模板--Android Studio 实现简易计算器App

目录 一、项目演示 二、项目测试环境 三、项目详情 四、完整的项目源码 一、项目演示 网络资源模板--基于Android studio 实现的简易计算器 二、项目测试环境 三、项目详情 动态绑定按钮&#xff1a; 使用循环遍历 buttons 数组&#xff0c;根据动态生成的按钮 ID (btn_0, …

SQL进阶技巧:如何删除第N次连续出现NULL值所存在的行?

目录 0 场景描述 1 数据准备 2 问题分析 问题拓展:如何删除第2次、第3次、第N次连续出现NULL值所在的行? 3 小结 0 场景描述 有下面的场景: 我们希望删除某id中连续存在NULL值的所有行,但是保留第一次出现不为NULL值的以下所有存在NULL值的行。具体如下图所示: 如…

iframe的使用详解

目录 一、基本概念和语法 二、优点 1.内容整合与复用&#xff1a; 2.独立的浏览环境&#xff1a; 3.跨域数据展示&#xff1a; 三、缺点 1.可访问性问题&#xff1a; 2.性能问题&#xff1a; 3.安全风险&#xff1a; 四、替代方案 1.使用JavaScript框架进行组件化开…

Unity开发Hololens项目

Unity打包Hololens设备 目录Visual Studio2019 / Visual Studio2022 远端部署设置Visual Studio2019 / Visual Studio2022 USB部署设置Hololens设备如何查找自身IPHololens设备门户Unity工程内的打包设置 目录 记录下自己做MR相关&#xff1a;Unity和HoloLens设备的历程。 Vi…

大规模多传感器滑坡检测数据集,利用landsat,哨兵2,planet,无人机图像等多种传感器采集数据共2w余副图像,mask准确标注滑坡位置

大规模多传感器滑坡检测数据集&#xff0c;利用landsat&#xff0c;哨兵2&#xff0c;planet&#xff0c;无人机图像等多种传感器采集数据共2w余副图像&#xff0c;mask准确标注滑坡位置 大规模多传感器滑坡检测数据集介绍 数据集概述 名称&#xff1a;大规模多传感器滑坡检测…

Python | Leetcode Python题解之第491题非递减子序列

题目&#xff1a; 题解&#xff1a; class Solution:def findSubsequences(self, nums: List[int]) -> List[List[int]]:def dfs(i, tmp):if i len(nums):if len(tmp) > 2:res.append(tmp[:]) # 拷贝&#xff0c;tmp[:]而非tmpreturn# 选 nums[i]if not tmp or nu…