SpringBoot是什么?
Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者。
Spring Boot它本身并不提供Spring框架的核心特性以及扩展功能,只是用于快速、敏捷地开发新一代基于Spring框架的应用程序。也就是说,它并不是用来替代Spring的解决方案,而是和Spring框架紧密结合用于提升Spring开发者体验的工具。
同时它集成了大量常用的第三方库配置(例如Jackson, JDBC, Mongo, Redis, Mail等等),Spring Boot应用中这些第三方库几乎可以零配置的开箱即用(out-of-the-box),大部分的Spring Boot应用都只需要非常少量的配置代码,开发者能够更加专注于业务逻辑
就像Maven一样,Maven整合所有的jar包,而spring boot整合了所有框架
注1:敏捷式开发
注2:spring boot其实不是什么新的框架,它默认配置了很多框架的使用方式,
就像maven整合了所有的jar包,spring boot整合了所有的框架
搭建项目
使用IDEA配置SpringBoot项目
在右边菜单选择Spring initalizr 选择好jdk版本,然后点击next,如果出现加载很久的话,应该是网络的原因,就点网址进去
创建成功后会打包成压缩包存放在本地
如果网络好的话,就会直接进入创建项目了
项目名一定不能 出现大写字母,不然不能创建项目,
创建实体类之类需要的东西
需要用到springmvc的框架就把他选上
创建完成,项目目录就是这样
你会发现这里没有webapp目录,因为spring boot 它默认就不推荐使用jsp,如果非要用也不是不可以,我们都知道jsp的性能不是很好,所以官方推荐使用HTML
在项目创建完成之后,它会默认配置启动类,点击main方法就可以启动项目了,而且是web项目,不需要配置tomcat
其他所有写的代码都必须要放到这个启动类的包里面,不然spring boot扫描不到
java源文件夹中的Springboot01Application.java是整个项目的启动类
static:存放的是静态资源的文件
templetes:存放的项目所需的页面
application.properties里面存放的是项目的全局配置信息
spring boot在默认的情况下,在resources默认有且仅有一个配置文件
static主要就是图片,templates主要放HTML页面
我把这个文件后缀改成yml,里面的内容就会变成非常有层次感,看个人喜欢吧
如果是要使用test的话
它里面的这个注解,就相当于spring与junit集成的两个注解
好了,介绍完了这些基本文件,就可以开始跑项目吧,也就是开始说的那个默认启动类,直接点击main方法运行就ok了
运行到浏览器去,出现这个就成功了,404就没有
下面来个入门案列
这里主要用到了这个注解:RestController
加了这个注解就是:这个类的方法默认返回的都是json对象
package com.tzp.springboot01.controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.HashMap;
import java.util.Map;
/**
* @author 心如止水
* @site www.xiaomage.com
* @company
* @create 2019-11-07 21:14
*
* RestController=controller+responsebody
*/
@RestController
public class HellowController {
// 上面加的这个注解所有这个类的方法默认返回的都是json对象
@RequestMapping("/hello1")
public String hello1(){
return "helloword springboot 世界美好与你环环相扣";
}
@RequestMapping("/hello2")
public Map hello2(){
Map map = new HashMap();
map.put("code",200);
map.put("msg","springboot 访问成功!!!");
return map;
}
}
它的访问成功说明springboot整合了springmvc,它不需要我们手动去整合,
Springboot配置文件
内置属性
application.yml
注意:实际项目开发的时候Port=80,Context-path=/,
server:
port: 80
servlet:
context-path: /
在访问浏览器的时候就是这个样子的,不用写端口号,项目名,直接请求方法就好了
自定义属性
Application.properties中配置
自定义属性属性在类中的应用
user:
uname: zs
pwd: 999
HellowController
@Value("${user.uname}")
private String uname;
@Value("${user.pwd}")
private String pwd;
@RequestMapping("/hello3")
public Map hello3(){
Map map = new HashMap();
map.put("uname",uname);
map.put("pwd",pwd);
return map;
}
属性封装类
定义属性封装类
package com.tzp.springboot01.entity;
import lombok.Data;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
/**
* @author 心如止水
* @site www.xiaomage.com
* @company
* @create 2019-11-07 22:42
*/
@ConfigurationProperties(
prefix = "user"
)
@Component
@Data
public class User {
// 加此注解get/set 方法就免了
private String uname;
private String pwd;
private Integer age;
private String sex;
}
由于需要用到上面的第一个注解所以导入一下依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
测试
package com.tzp.springboot01.controller;
import com.tzp.springboot01.entity.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.HashMap;
import java.util.Map;
/**
* @author 心如止水
* @site www.xiaomage.com
* @company
* @create 2019-11-07 21:14
*
* RestController=controller+responsebody
*/
@RestController
public class HellowController {
// 上面加的这个注解所有这个类的方法默认返回的都是json对象
@Value("${user.uname}")
private String uname;
@Value("${user.pwd}")
private String pwd;
@Autowired
private User user;
@RequestMapping("/hello4")
public User hello4(){
return user;
}
}
over~~~