Spring boot 快速入门

SpringBoot框架由Pivotal团队开发,旨在简化Spring应用的搭建和开发流程,提供开箱即用的第三方库配置,让开发者更专注于业务逻辑。本文详细介绍SpringBoot的配置、启动流程及如何快速创建项目。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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~~~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值