SpringBoot概述以及使用一

SpringBoot概述

概念

  • SpringBoot提供了一种快速使用Spring的方式,基于约定优于配置的思想,可以让开发人员不必在配置与逻
    辑业务之间进行思维的切换,全身心的投入到逻辑业务的代码编写中,从而大大提高了开发的效率,一定程度
    上缩短了项目周期。2014 年 4 月,Spring Boot 1.0.0 发布。Spring的顶级项目之一(https://spring.io)。

Spring 缺点

1.配置繁琐

  • 虽然Spring的组件代码是轻量级的,但它的配置却是重量级的。一开始,Spring用XML配置,而且是很多
    XML配置。Spring 2.5引入了基于注解的组件扫描,这消除了大量针对应用程序自身组件的显式XML配置。
    Spring 3.0引入了基于Java的配置,这是一种类型安全的可重构配置方式,可以代替XML。

2.依赖繁琐

  • 项目的依赖管理也是一件耗时耗力的事情。在环境搭建时,需要分析要导入哪些库的坐标,而且还需要分析导
    入与之有依赖关系的其他库的坐标,一旦选错了依赖的版本,随之而来的不兼容问题就会严重阻碍项目的开发
    进度。

SpringBoot功能

1.自动配置

  • SpringBoot的自动配置是一个运行时(更准确地说,是应用程序启动时)的过程,考虑了众多因素,才决定Spring配置应该用哪个,不该用哪个。该程序过程是SpringBoot自动完成的。

2.起步依赖

  • 起步依赖本质上是一个Maven项目对象模型(Project Object Model,POM),定义了对其他库的传递依赖,这些东西加在一起即支持某项功能。
    简单的说,起步依赖就是将具备某种功能的坐标打包到一起,并提供一些默认的功能。

3.辅助功能

  • 提供了一些大型项目中常见的非功能性特性,如嵌入式服务器、安全、指标,健康检测、外部配置等。

Spring Boot 并不是对 Spring 功能上的增强,而是提供了一种快速使用 Spring 的方式

二.SpringBoot快速入门

1.实现步骤

① 创建Maven项目
② 导入SpringBoot起步依赖

 <!-- Inherit defaults from Spring Boot -->
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.5.9.RELEASE</version>
    </parent>

    <!-- Add typical dependencies for a web application -->
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
    </dependencies>

    <!-- Package as an executable jar -->
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

③ 定义Controller

@RestController
public class HelloController {
    @RequestMapping("/hello")
    public String hello(){
        return  "hello Spring Boot !";
    }
}

④ 编写引导类

/*
* 引导类。SpringBoot项目的入口
* */
@SpringBootApplication
public class HelloApplication {

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

⑤ 启动测试

三.SpringBoot配置

3.1 配置文件分类

SpringBoot是基于约定的,所以很多配置都有默认值,但如果想使用自己的配置替换默认配置的话,就可以使用
application.properties或者application.yml(application.yaml)进行配置。

properties:

	server.port=8080

yml:

	server:
		port:  8080

⚫ SpringBoot提供了2种配置文件类型:properteis和yml/yaml
⚫ 默认配置文件名称:application
⚫ 在同一级目录下优先级为:properties > yml > yaml

3.2 yaml

YAML全称是 YAML Ain’t Markup Language 。YAML是一种直观的能够被电脑识别的的数据数据序列化格式,并且容易被人类阅读,容易和脚本语言交互的,可以被支持YAML库的不同的编程语言程序导入,比如: C/C++, Ruby, Python,Java, Perl, C#, PHP等。YML文件是以数据为核心的,比传统的xml方式更加简洁。
YAML文件的扩展名可以使用.yml或者.yaml。

  • properties:
server.port=8080
server.address=127.0.0.1
  • xml:
<server> 
	<port>8080</port> 
	<address>127.0.0.1</address>
</server> 
  • yml:
server: 
	port: 8080
	address: 127.0.0.1

简洁,以数据为核心

3.2.1 YAML:基本语法

  • 大小写敏感
    数据值前边必须有空格,作为分隔符
    使用缩进表示层级关系
    缩进不允许使用Tab键,只允许使用空格。
    #表示注释,从这个字符到尾会被注释掉。

3.2.2 YAML:数据格式

  • 对象(map):键值对的集合
person:
	name: zhangsan
#行内写法
person: {name: zhangsan}
  • 数组:一组按次序排序的值
address:
 - beijing
 - shanghai
#行内写法
address: [beijing,shanghai]
  • 纯量: 单个的,不可再分的值
msg1: 'hello \n world' 	#单引忽略转义字符
msg2: "hello \n world"	#双引识别转义字符
  • yaml:参数引用
name: lisi
person:
	name: ${name} #引用上边定义的name值

3.3 读取配置文件内容

application.yml

server:
	port: 8080
name: abc
#对象
person:
	name: zhangsan 
	age: 20
#数组
address:
	- beijing
	- shanghai
//1.@Value
//单个注入
@Value("${name}")  
private String name;

//2.Environment类的实例存放的时spring容器的配置信息
@Autowired
private Environment env; //使用的是 org.springframework.core.env
//调用
System.out.println(env.getProperty("person.name"));

//3.@ConfigurationProperties
@Component //创建对象,实例化到spring容器中
@ConfigurationProperties(prefix = "person")
public class Person{
	private String name;
	private int age;
	private String[] address;
}

加入依赖,写配置文件的时候可以提示

<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-configuration-processor</artifactId>
	<optional>true</optional>
</dependency>

3.4 profile

我们在开发Spring Boot应用时,通常同一套程序会被安装到不同环境,比如:开发、测试、生产等。其中数据库地址、服务器端口等等配置都不同,如果每次打包时,都要修改配置文件,那么非常麻烦。profile功能就是来进行动态配置切换的。

3.4.1 profile配合方式

  • 多profiles文件方式

application.properties

spring.profiles.active=pro(dev,pro,test写的哪个就用哪个的数据)

application-dev.properties

server.port=8082

application-pro.properties

server.port=8083

application-test.properties

server.port=8084
  • yml多文档方式 — 分隔不同配置
---
server: 
  port: 8081
spring: 
  profiles: dev
---
server:
  port: 8082
spring:
  profiles: test
---
server:
  prot: 8083
spring:
  profiles: pro
---
spring:
  profiles:
  	active: pro

3.4.2 profile激活方式

  • 配置文件
  • 虚拟机参数
    使用ideal
    在这里插入图片描述
  • 命令行参数
    java-jar xxx.jar --spring.profiles.active=dev
    在这里插入图片描述

3.5 内部配置加载顺序

  1. file:./config/:当前项目下的/config目录下
  2. file:./ :当前项目的根目录
  3. classpath:/config/:classpath的/config目录
  4. classpath:/ :classpath的根目录

加载顺序为上文的排列顺序,高优先级配置的属性会生效

四.SpringBoot整合其他框架

4.1 SpringBoot整合Junit

① 搭建SpringBoot工程
② 引入starter-test起步依赖
③ 编写测试类
④ 添加测试相关注解

/*
* userService的测试类
* */
@SpringBootTest(classes = SpringbootTestApplication.class)
class UserServiceTest {
    @Autowired
    private UserService userService;

    @Test
    public void testadd() {
        userService.add();
    }
}

⑤ 编写测试方法

4.2 SpringBoot整合Redis

① 搭建SpringBoot工程
② 引入redis起步依赖
③ 配置redis相关属性
④ 注入RedisTemplate模板
⑤ 编写测试方法,测试

@SpringBootTest
class SpringbootRedisApplicationTests {

    @Autowired
    private RedisTemplate redisTemplate;

    @Test
    public void testSet() {
        //存入数据
        redisTemplate.boundValueOps("name").set("zhangsan");
    }
    @Test
    public void testGet(){
        //获取数据
        Object name = redisTemplate.boundValueOps("name").get();
        System.out.println(name);
    }
}

4.3 SpringBoot整合Mybatis

① 搭建SpringBoot工程
② 引入mybatis起步依赖,添加mysql驱动
③ 编写DataSource和MyBatis相关配置

#dataSource
spring:
  datasource:
    url: jdbc:mysql:///springboot
    username: root
    password: 333
    driver-class-name: com.mysql.jdbc.Driver
#mybatis
mybatis:
	mapper-locations: classpath:mapper/*Mapper.xml #mapper映射文件路径
	type-aliases-package: com.tx.springbootmybatis.domain

	#config-locations: #指定mybatis的核心配置文件

④ 定义表和实体类
⑤ 编写dao和mapper文件/纯注解开发

@Mapper
public interface UserMapper {

    @Select("select * from t_user")
    public List<user> findAll();
}

⑥ 测试

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值