Spring-Boot Spring的春天
在之前我们一直使用Spring、SpringMVC进行开发,的确,Spring让我们认识到了项目开发原来可以这么方便。但是大量的配置文件却是令人头痛的,即使我们想写一个简单的请求映射并在浏览器上发送Get请求测试,那么需要:1.在web.xml中配置DispatcherServlet; 2.在application.xml中配置注解扫描、注解驱动。可以看到:虽然Spring是轻量级的,但是Spring的配置却是重量级的。并且搭建每个Spring项目我们都需要考虑依赖版本是否冲突的问题…
So,SpringBoot将这一切都解决了。SpringBoot提供了一种固定的、约定优于配置风格的框架,让开发者能更快的创建基于Spring的应用程序和服务。
对应的SpringBoot整合Mybatis实现CRUD的项目和笔记请看我的Github仓库:教你优雅的入门Spring Boot框架
如果觉得不错就点击右上角star鼓励一下笔者吧(#.#)
SpringBoot有如下特性:
- 更高效的创建基于Spring的应用服务
- 无需XML配置,可以修改默认值来满足特定的需求
- 提供了一些大型项目中常见的非功能性特性,如嵌入式服务器、安全…
- Spring Boot并不是对Spring功能上的增强,而是提供了一种快速使用Spring的方式
SpringBoot项目搭建
这里我选择使用IDEA来创建SpringBoot项目:
1.选择Spring Initializr,并选择本地的JDK版本
2.Next,指定Group和Artifact名称,并选择本机JDK版本
3.选择项目所需依赖
解释
devtools
: SpringBoot提供的热部署插件,可以避免每次修改代码都要重新启动项目。。
lomback
: 使用Lomback可以减少项目中很多重复代码的书写,比如getter/setter/toString等方法的书写(虽然这些可能我们都是用的快捷键生成的代码)。具体用法可以参考博文:lomback介绍
Thymeleaf
: 语法的支持
注意: 以上依赖非必选,如果仅仅想尝试一下Spring Boot-HelloWorld,只需要选择其中的web
依赖即可。
SpringBoot起步
以上是新创建的Spring Boot项目。在SpringBoot中有一个启动器(引导类)的概念,我们首先看一下SpringbootApplication.java
:
@SpringBootApplication
public class SpringbootApplication {
public static void main(String[] args) {
SpringApplication.run(SpringbootApplication.class, args);
}
}
@SpringBootApplication
public class SpringbootApplication {
public static void main(String[] args) {
SpringApplication.run(SpringbootApplication.class, args);
}
}
如上,仅是一个简单的main方法,其中最核心的就是@SpringBootApplication
注解,它是一下三个注解的总和:
-
@Configuration
: 用于定义一个配置类。 -
@EnableAutoConfiguration
: SpringBoot会自动根据你的jar包依赖来自动配置项目。 -
@ComponentSacn
: 告诉Spring哪个packages的用注解标识的类会被Spring自动扫描并且转入Bean容器。
通过以上三个注解你就应该了解到了SpringBoot的作用:自动化配置项目。之前我们要手动进行的XML配置在这里仅需要这一个注解就完成了。且SpringBoot项目不需要单独部署到Tomcat中才能启动,通过这个启动器,SpringBoot会自动构建一个web容器,并将项目部署到其中。
So,
Run SpringBootApplication
发现报错,说DataSource
数据源的url地址没有配置。之前我们提到了SpringBoot的特性就是自动化配置,它会根据你的依赖文件来配置项目,我们再看一下我们的pom.xml
:
其中最上层的<parent>
节点约束了整个下面所有spring-boot依赖的版本,即这里使用了SpringBoot-2.0.5。然后关注<dependencies>
节点下的前四个依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.2</version>
</dependency>
Spring Boot应用启动器
spring-boot-starter
: Spring Boot的核心启动器,包含了自动配置、日志和YAML。
spring-boot-starter-jdbc
: 支持JDBC数据库。
spring-boot-starter-thymeleaf
: 支持Thymeleaf模板引擎,包括与Spring的集成。
spring-boot-starter-web
: 支持全栈式开发,包括Tomcat和Spring-WebMVC。
mybatis-spring-boot-starter
: 整合spring-mybatis依赖。
前面我们强调的一点是Spring Boot能实现自动化配置,那么项目的依赖就决定了Spring Boot将如何自动配置项目,Spring Boot的启动器就决定了项目会以什么样的配置启动项目;如此,我们会明白这个报错是为什么了。
因为我们配置配置JDBC连接的数据库,所以报错,注释掉spring-boot-starter-jdbc
和mybatis-spring-boot-starter
依赖,再次启动SpringBootApplication
:
启动成功。
测试
在src/main/java/cn/tycoding/springboot/
下创建controller
文件夹并创建LoginController.java
类:
@RestController
public class LoginController {
@RequestMapping("/login")
public String login(@RequestParam("username") String username, @RequestParam("password") String password) {
System.out.println("username:" + username + ", password:" + password);
return null;
}
}
@RestController
public class LoginController {
@RequestMapping("/login")
public String login(@RequestParam("username") String username, @RequestParam("password") String password) {
System.out.println("username:" + username + ", password:" + password);
return null;
}
}
如上就完成了在SSM阶段一个最基本的SpringMVC Controller映射方法的书写,那么测试一下:
在浏览器上访问:
localhost:8080/login?username=tycoding&password=123
后端即可接收到username和password参数。
这时你会发现,SpringBoot内置的Web容器默认访问地址就是8080端口,如果想改变这个默认端口,修改src/main/resources/application.properties
:
server.port=8088
重启SpringbootApplication
,访问:localhost:8088/login?username=tycoding&password=123
读取配置文件信息
在src/main/resources/application.properties
中添加配置:
url=http://www.tycoding.cn
在LoginController.java
中添加映射方法:
@RestController
public class LoginController {
@Autowired
private Environment environment;
@RequestMapping("/blog")
public String login(){
return environment.getProperty("url");
}
}
@RestController
public class LoginController {
@Autowired
private Environment environment;
@RequestMapping("/blog")
public String login(){
return environment.getProperty("url");
}
}
Spring提供的Environment
类用户读取配置文件中参数,访问:localhost:8088/blog
即可得到。