springboot搭建maven项⽬第⼀步:新建项⽬
选择 Spring Initializr ,然后选择默认的 url 点击【Next】:
然后修改⼀下项⽬的信息:
勾选上 Web 模板:
选择好项⽬的位置,点击【Finish】:
如果是第⼀次配置 Spring Boot 的话可能需要等待⼀会⼉ IDEA 下载相应的依赖包,默认创建好的项⽬结构如下:
项⽬结构还是看上去挺清爽的,少了很多配置⽂件,我们来了解⼀下默认⽣成的有什么:
SpringbootApplication:⼀个带有 main() ⽅法的类,⽤于启动应⽤程序
SpringbootApplicationTests:⼀个空的 Junit 测试了,它加载了⼀个使⽤ Spring Boot 字典配置功能的 Spring 应⽤程序上下⽂application.properties:⼀个空的 properties ⽂件,可以根据需要添加配置属
性
第⼆步:HelloController
在【cn.wmyskxz.springboot】包下新建⼀个【HelloController】:
package cn.wmyskxz.springboot;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;spring mvc和boot区别
/**
* 测试控制器
*
* @author: @我没有三颗⼼脏
* @create: 2018-05-08-下午 16:46
*/
@RestController
public class HelloController {
@RequestMapping("/hello")
public String hello() {
return "Hello Spring Boot!";
}
}
@RestController 注解:该注解是 @Controller 和 @ResponseBody 注解的合体版
第三步:利⽤ IDEA 启动 Spring Boot
我们回到 SpringbootApplication 这个类中,然后右键点击运⾏:
注意:我们之所以在上⾯的项⽬中没有⼿动的去配置 Tomcat 服务器,是因为 Spring Boot 内置了 Tomcat 等待⼀会⼉就会看到下⽅的成功运⾏的提⽰信息:
可以看到我们的 Tomcat 运⾏在 8080 端⼝,我们来访问 “/hello” 地址试⼀下:
可以看到页⾯成功显⽰出我们返回的信息。
解析 Spring Boot 项⽬
这⼀部分参考⾃:
解析 l ⽂件
让我们来看看默认⽣成的 l ⽂件中到底有⼀些什么特别:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="/POM/4.0.0" xmlns:xsi="/2001/XMLSchema-instance"
xsi:schemaLocation="/POM/4.0.0 /xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>cn.wmyskxz</groupId>
<artifactId>springboot</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>springboot</name>
<description>Demo project for Spring Boot</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.1.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
&porting.outputEncoding>UTF-8</porting.outputEncoding>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
我们可以看到⼀个⽐较陌⽣⼀些的标签<parent>,这个标签是在配置 Spring Boot 的⽗级依赖:
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.1.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
有了这个,当前的项⽬才是 Spring Boot 项⽬,spring-boot-starter-parent 是⼀个特殊的 starter ,它⽤来提供相关的 Maven 默认依赖,使⽤它之后,常⽤的包依赖就可以省去version 标签。
关于具体 Spring Boot 提供了哪些 jar 包的依赖,我们可以查看本地 Maven 仓库下:\repository\org\springframework\boot\spring-boot-dependencies\2.0.1.RELEASE\spring-boot-dependencies-2.0.1.RELEASE.pom ⽂件来查看,挺长的...
应⽤⼊⼝类
Spring Boot 项⽬通常有⼀个名为 *Application 的⼊⼝类,⼊⼝类⾥有⼀个 main ⽅法,这个 main ⽅法其实就是⼀个标准的 Javay 应⽤的⼊⼝⽅法。
@SpringBootApplication 是 Spring Boot 的核⼼注解,它是⼀个组合注解,该注解组合了:@Configuration、@EnableAutoConfiguration、@ComponentScan;若不是⽤
@SpringBootApplication 注解也可以使⽤这三个注解代替。
其中,@EnableAutoConfiguration 让 Spring Boot 根据类路径中的 jar 包依赖为当前项⽬进⾏⾃动配置,例如,添加了 spring-boot-starter-web 依赖,会⾃动添加 Tomcat 和 Spring MVC 的依赖,那么 Spring Boot 会对 Tomcat 和 Spring MVC 进⾏⾃动配置。
Spring Boot 还会⾃动扫描 @SpringBootApplication 所在类的同级包以及下级包⾥的 Bean ,所以⼊⼝类建议就配置在 grounpID + arctifactID 组合的包名下(这⾥为cn.wmyskxz.springboot 包)
Spring Boot 的配置⽂件
Spring Boot 使⽤⼀个全局的配置⽂件 application.properties 或 l,放置在【src/main/resources】⽬录或者类路径的 /config 下。
Spring Boot 不仅⽀持常规的 properties 配置⽂件,还⽀持 yaml 语⾔的配置⽂件。yaml 是以数据为中⼼的语⾔,在配置数据的时候具有⾯向对象的特征。
Spring Boot 的全局配置⽂件的作⽤是对⼀些默认配置的配置值进⾏修改。
简单实例⼀下
我们同样的将 Tomcat 默认端⼝设置为 8080 ,并将默认的访问路径从 “/” 修改为 “/hello” 时,使⽤ properties ⽂件和 yml ⽂件的区别如上图。
注意: yml 需要在 “:” 后加⼀个空格,幸好 IDEA 很好地⽀持了 yml ⽂件的格式有良好的代码提⽰;
我们可以⾃⼰配置多个属性
我们直接把 .properties 后缀的⽂件删掉,使⽤ .yml ⽂件来进⾏简单的配置,然后使⽤ @Value 来获取配置属性:
重启 Spring Boot ,输⼊地址:localhost:8080/hello 能看到正确的结果:
注意:我们并没有在 yml ⽂件中注明属性的类型,⽽是在使⽤的时候定义的。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论