springboot 简明教程

本文是SpringBoot简明教程,主要讲解了Spring的全注解配置,包括@Configuration、@Bean等注解的使用,以及SpringBoot的注解配置,如属性注入、更优雅的注入方式。接着探讨了SpringBoot自动配置的原理,@SpringBootApplication注解的三个关键部分:@SpringBootConfiguration、@EnableAutoConfiguration和@ComponentScan。此外,还介绍了如何整合SpringMVC和Thymeleaf。
摘要由CSDN通过智能技术生成

SpringBoot

SpringBoot,其实就是整合了的 SSM

其中最关键的一点,就是 约定大于配置

即 SpringBoot 默认使用者都使用同一约定构建项目,这样,就可以在不使用配置文件的情况下,让 SpringBoot 完成大量繁杂的配置工作,从而避免 配置地狱!!

一、Spring 全注解配置

在讲解 SpringBoot 的配置之前,我们先来了解一下 Spring 的全注解配置

所谓全注解配置,就是不使用 .xml 去写配置文件,而是在 java 代码中,用注解去替代配置文件

Spring 1.0无,Spring2.0 开始推荐,Spring3.0 趋于完善

Spring 全注解配置在国外比较火,但是在国内用的人比较少

1、常用注解

@Configuration :声明一个类作为配置类,代替xml文件

@Bean :声明在方法上,将方法的返回值加入Bean容器,代替 标签 @value :属性注入

@PropertySource :指定外部属性文件

2、配置实例

我们接下来用java配置来尝试实现连接池配置:

1、引入 druid 依赖

 <dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid</artifactId>
    <version>1.1.10</version>
</dependency>

2、创建 jdbc.properties 配置文件

jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://127.0.0.1:3306/lxs
jdbc.username=root
jdbc.password=123

3、编写配置代码

@Configuration
@PropertySource("classpath:jdbc.properties")
public class JdbcConfig {
    @Value("${jdbc.url}")
    String url;
    @Value("${jdbc.driverClassName}")
    String driverClassName;
    @Value("${jdbc.username}")
    String username;
    @Value("${jdbc.password}")
    String password;
  
@Bean
    public DataSource dataSource() {
        DruidDataSource dataSource = new DruidDataSource();
        dataSource.setUrl(url);
        dataSource.setDriverClassName(driverClassName);
        dataSource.setUsername(username);
        dataSource.setPassword(password);
        return dataSource;
} }
@Configuration :声明我们 JdbcConfig 是一个配置类

@PropertySource :指定属性文件的路径是: classpath:jdbc.properties
通过 @Value 为属性注入值

@Bean将 dataSource() 方法声明为一个注册Bean的方法,Spring会自动调用该方法,将方法的返回值 加入Spring容器中。默认的对象名id=方法名,可以通过@Bean("自定义名字"),来指定新的对象名

4、然后我们就可以在任意位置通过 @Autowired 注入DataSource了

@RestController
public class HelloController {
  
    @Autowired
    private DataSource dataSource;
  
 
    @GetMapping("hello")
    public String hello() {
        return "hello, spring boot!" + dataSource;
    }
}

二、SpringBoot 注解配置

在了解了 Spring 的注解配置后,我们就可以来学习 SpringBoot 的注解配置了。

1、SpringBoot 属性注入

在上面的案例中,我们实验了java配置方式。不过属性注入使用的是@Value注解。这种方式虽然可行,但是不够强大,因为它只能注入基本类型值。 在SpringBoot中,提供了一种新的属性注入方式,支持各种java基本数据类型及复杂类型的注入。

1、新建一个类,用来进行属性注入

相当于,把一个配置文件的信息,用一个类来承接,后面我们要操作配置文件,其实就是操作这个类

@ConfigurationProperties(prefix = "jdbc")
public class JdbcProperties {
    private String url;
    private String driverClassName; 
  	private String username; 
  	private String password;
    // ... 略
    // getters 和 setters
}
  • 在类上通过@ConfigurationProperties注解声明当前类为属性读取类

  • prefix=“jdbc” 读取属性文件中,前缀为jdbc的值。

image-20210613164141763
  • 在类上定义各个属性,名称必须与属性文件中 jdbc. 后面部分一致

  • 需要注意的是,这里我们并没有指定属性文件的地址,所以我们需要把jdbc.properties名称改为 application.properties,这是SpringBoot默认读取的属性文件名:

image-20210613164122477

2、在JdbcConfig中使用这个属性

@Configuration
@EnableConfigurationProperties(JdbcProperties.class)
public class JdbcConfig {
  
@Bean
    public DataSource dataSource(JdbcProperties jdbc) {
        DruidDataSource dataSource = new DruidDataSource();
        dataSource.setUrl(jdbc.getUrl());
        dataSource.setDriverClassName(jdbc.getDriverClassName());
        dataSource.setUsername(jdbc.getUsername());
        dataSource.setPassword(jdbc.getPassword());
        return dataSource;
    }
}

通过 @EnableConfigurationProperties(JdbcProperties.class) 来声明要使用 JdbcProperties 这个类的对象

上面缀 JdbcProperties 的方式,其实有三种:

1)@Autowired注入

@Autowired
private JdbcProperties prop;

2)构造函数注入

private JdbcProperties prop;
public JdbcConfig(Jdbcproperties prop){
    this.prop = prop;
}

3)声明有@Bean的方法参数注入

建议使用这种方法,因为不需要显示的声明成员变量

@Bean
public Datasource dataSource(JdbcProperties prop){
    // ...
}

在本例中,我们使用的就是第三种方法。

3、小结

上面的注入方式,看起来比 Spring 的注解注入方式还要麻烦

但是,这种方式才是 SpringBoot 的推荐注入方法,其和 Spring 的注解注入方式优劣对比如下:

image-20210613165420560

2、SpringBoot 更优雅的注入方式

事实上,如果一段属性只有一个Bean需要使用,我们无需将其注入到一个类(JdbcProperties)中。而是直接在需要的地方声明即可:

但是一定要注意,配置文件中的属性名,一定要与被注入对象的属性名一致!

image-20210613170028559

@Configuration
public class JdbcConfig {
@Bean
// 声明要注入的属性前缀,SpringBoot会自动把相关属性通过set方法注入到DataSource中 
@ConfigurationProperties(prefix = "jdbc")
public DataSource dataSource() {
        DruidDataSource dataSource = new DruidDataSource();
        return dataSource;
    }
}

我们直接把 @ConfigurationProperties(prefix = “jdbc”) 声明在需要使用的 @Bean 的方法上,然后SpringBoot 就会自动调用这个Bean(此处是DataSource)的set方法,然后完成注入。使用的前提是:该类必须有对应属性的 set方法!

三、自动配置原理

通过刚才的案例看到,一个整合了SpringMVC的WEB工程开发,变的无比简单,那些繁杂的配置都消失不见了。

这是如何做到的? 这些都是从springboot启动器开始的

1、@SpringBootApplication

我们来看一下启动类的 @SpringBootApplication 注解的源码:

image-20210613174841104

其中的

@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan

是我们重点关注的对象

1-1、@SpringBootConfiguration

该注解的源码中,还有一个 @Configuration 注解,说明 SpringBoot 启动类,其实,就是一个配置类。Spring会自动扫描到添加了 @Configuration 的类,并且读取其中的配置信息。

image-20210613175027578

1-2、@EnableAutoConfiguration

第二级的注解 @EnableAutoConfiguration ,告诉SpringBoot基于你所添加的依赖,去“猜测”你想要如何配置 Spring。比如我们引入了 spring-boot-starter-web ,而这个启动器中帮我们添加了 tomcat 、 SpringMVC 的 依赖。此时自动配置就知道你是要开发一个web应用,所以就帮你完成了web及SpringMVC的默认配置了!

通俗一点讲,就是 SpringBoot内部对大量的第三方库进行了默认配置,我们引入对应库所需的依赖,那么默认配置就会生效。

1-3、@ComponentScan

image-20210613182430931

去看注解,我们大致可以得知,这个注解的作用,是去配置扫描包的

配置组件扫描的指令。提供了类似与 <context:component-scan> 标签的作用 通过basePackageClasses或者basePackages属性来指定要扫描的包。如果没有指定这些属性,那么将从声明这个注解的类所在的包开始,扫描包及子包

2、默认配置原理

2-1、概念

@EnableAutoConfiguration会开启SpringBoot的自动配置,并且根据你引入的依赖来生效对应的默认配置, springboot如何做到的?

其实在我们的项目中,已经引入了一个依赖:spring-boot-autoconfigure,其中定义了大量自动配置类:

image-20210613183333324

非常多,几乎涵盖了现在主流的开源框架,例如:
redis jms amqp jdbc jackson mongodb jpa solr elasticsearch … 等等

2-2、配置实例

我们来看一个我们熟悉的,例如SpringMVC,查看mvc 的自动配置类:

image-20210613210327716

2-3、小结

SpringBoot为我们提供了默认配置,而默认配置生效的条件一般有两个:

1)引入了相关依赖

2)没有自定义配置类

四、整合第三方框架

1、整合 SpringMVC

1-1、修改端口

只要在全局配置文件中,加上如下配置即可:

server.port=8088
1-2、静态资源

springMVC中,配置静态资源访问,是使用如下方式的:

image-20210613211245553

但在 SpringBoot 中,因为有自动配置,所以会方便很多

配置类中,给了静态资源的放置路径,有如下几个

classpath:/META-INF/resources/ 
classpath:/resources/ 
classpath:/static/ 
classpath:/public

image-20210613211443125

但是,我们一般习惯放在 resources/static 文件夹下:

image-20210613211551784

只要放置在 /resources/static 目录下,SpringMVC 都会帮我们处理

但如果静态资源还被拦截的话,可以自定义配置,配置对静态资源不要进行拦截:

@Configuration
public class MyMvcConfig implements WebMvcConfigurer {

    @Override
    public void addViewControllers(ViewControllerRegistry registry) {
        registry.addViewController("/").setViewName("login");
        registry.addViewController("/login.html").setViewName("login");
        registry.addViewController("/index.html").setViewName("index");
    }

    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("classpath:/static/");
    }
}

image-20210613211907213

1-3、拦截器配置

1、编写拦截器

public class LoginInterceptor implements HandlerInterceptor {

    private static final Logger LOG= LoggerFactory.getLogger(LoginInterceptor.class);

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        LOG.info("处理器执行前");
        return true;
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        LOG.info("处理器执行后");
    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        LOG.info("跳转后执行");
    }
}

2、配置拦截器

这里要注意两点:

1)需要将我们自定义的 Interceptor 交给 spring 管理(使用 @Bean 注解)

2)需要为我们的拦截器,配置拦截路径

@Configuration
public class MyMvcConfig implements WebMvcConfigurer {

    /**
     * 通过@Bean注解,将我们定义的拦截器注册到Spring容器
     * @return
     */
    @Bean
    public LoginInterceptor loginInterceptor() {
        return new LoginInterceptor();
    }

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(this.loginInterceptor())
                .addPathPatterns("/**");
    }
}

2、整合 Mybatis

SpringBoot官方并没有提供Mybatis的启动器,不过Mybatis官网自己实现了

1)引入 maven 依赖

 <!--mybatis -->
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>1.3.2</version>
</dependency>

2)编写配置文件

# mybatis 别名扫描 
mybatis.type-aliases-package=com.lxs.domain
# mapper.xml文件位置,如果没有映射文件,请注释掉 
mybatis.mapper-locations=classpath:mappers/*.xml

3)编写实体类,接口

这里就略了

4)编写映射文件

 <?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.lxs.demo.dao.UserDao">
    <select id="findAll" resultType="user">
        select * from tb_user
    </select>
</mapper>

5)加载接口代理对象

在 springboot 的启动类中,加上注解,告诉 Spring 接口的位置

@SpringBootApplication
@MapperScan("com.lxs.demo.dao")
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
} }

五、Thymeleaf

thymeleaf ,可以看成升级版的 JSP,二者都是模板引擎

JSP 的工作原理,是被编译成 java 代码,然后执行,也就是说,只有在服务器启动后,jsp 的页面才可以被渲染出来

但是 thymeleaf 的页面展示不需要依赖服务器,如果服务器没启动,无法调用后端接口,thymeleaf 中可以伪造数据,从而让前端开发人员查案数据展示的效果

使用 thymeleaf ,使得前后端分离开发成为可能

通过源码分析,我们可以看到,对 thymeleaf 的视图解析器配置,是默认将页面,放在 resources/thymrleaf 文件夹下的

image-20210614011710235

  • 默认前缀: classpath:/templates/
  • 默认后缀: .html

一些常用语法如下:

image-20210614011803194

还有很多 yhymeleaf 的标签内容,放在这里,估计也不会看,如果真要使用的话,可以上网查询,用多了,就熟悉了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

FARO_Z

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

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

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

打赏作者

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

抵扣说明:

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

余额充值