1、Spring-boot目的

Spring-boot目的

Spring是为了解决企业应用开发的复杂性而创建的,简化开发

Spring如何简化开发

1.基于POJO的轻量级和最小侵入性编程

2.通过IOC,依赖注入(DI)和面向接口实现松耦合

3.基于(AOP)和惯例进行声明式编程

4.基于切面和模板减少样式代码

微服务

第一个spring-boot程序

官方提供了一个快速生成的网站!idea集成了这个网站

1可以在官网下载后,导入idea开发(官网)
2直接使用idea创建一个springboot项目(一般直接在idea创建)

自动配置原理

自动配置:pom.xml

​ spring-boot-dependencies:核心依赖在父工程中

​ 我们在写或者引入一些springboot依赖的时候,不需要指定版本就是因为有这些版本仓库

启动器

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter</artifactId>
</dependency>

启动器:说白了就是SpringBoot的场景启动器

比如spring-boot-starter,他就会帮我们自动导入web环境所有依赖

springboot会将所有的功能场景,都变成一个个的启动器

我们要使用什么功能,就只需要找到对应的启动器就可以了start

主程序
//标注这个类是一个springboot应用
@SpringBootApplication
public class SpringBoot01HelloworldApplication {

    public static void main(String[] args) {
        SpringApplication.run(SpringBoot01HelloworldApplication.class, args);
    }

}
@SpringBootConfiguration	springboot的配置
		往下
	@configuation	spring配置类
		往下
	@Component:说明是一个spring组件
@EnableAutoConfiguration	:自动配置
	@@AutoConfigurationPackage:自动配置包
	@Import(@AutoConfigurationPackage.Registrar.class):自动配置包注册
	@Import({AutoConfigurationImportSelector.class}):自动导入选择(组件)
	
	List<String> configurations = this.getCandidateConfigurations(annotationMetadata, attributes);
	获得所有的配置
获取候选的配置
protected List<String> getCandidateConfigurations(AnnotationMetadata metadata, AnnotationAttributes attributes) {
    List<String> configurations = SpringFactoriesLoader.loadFactoryNames(this.getSpringFactoriesLoaderFactoryClass(), this.getBeanClassLoader());
    Assert.notEmpty(configurations, "No auto configuration classes found in META-INF/spring.factories. If you are using a custom packaging, make sure that file is correct.");
    return configurations;
}
META-INF/spring.factories自动配置的核心文件

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vh4Wfblf-1631189148601)(C:\Users\你在教我作事?\AppData\Roaming\Typora\typora-user-images\image-20210822142136925.png)]

Properties properties = PropertiesLoaderUtils.loadProperties(resource); 所有资源加载到配置类中
结论:

​ springboot所有自动配置都是在启动的时候扫描并加载spring-factories所有的自动配置类都在里面,但是不一定生效,要判断条件是否成立,要判断是否成立,只要导入对应的start,就有对应的启动器,有了启动器,我们自动装配就会生效,然后就2配置成功了

1.springboot在启动的时候,从类的路径下/META-INF/spring.factories获取指定的值;

2.将这些自动配置的类导入容器 自动配置类就会生效,帮我们进行自动配置

3.一起我们需要自动配置的东西,现在springboot帮我们做了

4.整合javaEE,解决方案和自动配置的东西都在spring-boot-autoconfigure-2.3.7.RELEASE.jar

5.他会把所有需要导入的组件,以类名方式返回,这些组件就会被添加到容器;

6、容器中也会存在非常多的xxxAutoConfiguration的文件(@Bean),就是这些容器中导入了这个场景需要的所有组件并自动配置,@Configuration,javaConfig!

7.有了自动配置类,免去了我们手动编写配置文件的工作

SpringApplication.run(SpringBoot01HelloworldApplication.class, args);
 SpringApplication加载主类
 这个类主要做了以下四件事情
 1.判断应用的类型的普通的项目还是web项目
 2.查找并加载所有可用初始化器,设置到initializers属性中
 3.找出所有的应用程序监听器,设置到listeners属性中
 4.推断并设置main方法的定义类,找到运行的主类

javaConfig @Configuration @Bean

Docker:进程
tializers属性中
3.找出所有的应用程序监听器,设置到listeners属性中
4.推断并设置main方法的定义类,找到运行的主类


javaConfig @Configuration @Bean

Docker:进程
Spring-Boot WebSocket 可以实现向日葵远程控制。向日葵是一款远程控制软件,可以让我们在远程控制设备时更加方便和灵活。在使用Spring-Boot实现WebSocket时,我们可以结合向日葵的API来达到远程控制的目的。 首先,在Spring-Boot中,我们需要引入WebSocket的依赖。可以在pom.xml文件中添加相应的依赖,例如: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-websocket</artifactId> </dependency> ``` 然后,我们需要创建WebSocket的配置类。在配置类中,我们可以定义WebSocket的相关设置,例如消息处理器、握手拦截器等。可以参考以下代码: ``` @Configuration @EnableWebSocket public class WebSocketConfig implements WebSocketConfigurer { @Override public void registerWebSocketHandlers(WebSocketHandlerRegistry registry) { registry.addHandler(myHandler(), "/myHandler").withSockJS(); } @Bean public WebSocketHandler myHandler() { return new MyHandler(); } } ``` 在以上代码中,`registerWebSocketHandlers` 方法用来注册WebSocket处理器,并指定了处理路径。`MyHandler` 是自定义的消息处理器,可以在其中处理接收到的消息、发送消息等。 接下来,我们可以在处理器中调用向日葵的API,实现远程控制的功能。例如: ``` public class MyHandler extends TextWebSocketHandler { @Override protected void handleTextMessage(WebSocketSession session, TextMessage message) throws Exception { // 处理接收到的消息 String receivedMessage = message.getPayload(); // 调用向日葵API,实现远程控制 // 发送消息 String responseMessage = "远程控制成功"; session.sendMessage(new TextMessage(responseMessage)); } } ``` 在以上代码中,`handleTextMessage` 方法用来处理接收到的消息。我们可以在其中调用向日葵的API实现远程控制的逻辑,并将结果作为消息发送回客户端。 最后,在Spring-Boot的主类中添加 `@EnableWebSocket` 注解,启用WebSocket功能。 综上所述,通过Spring-Boot WebSocket,我们可以便捷地实现向日葵远程控制的功能。使用WebSocket协议进行通信,同时结合向日葵的API,可以让我们更加灵活地远程控制设备。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

夏来梦栀子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值