1.Springboot概念及第一个SpringBoot程序

时间:2021-09-05
本文章向大家介绍1.Springboot概念及第一个SpringBoot程序,主要包括1.Springboot概念及第一个SpringBoot程序使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

1.什么是Springboot

springboot就是javaweb的开发框架,和springMVC类似,好处就是简化开发:约定大于配置。能迅速开发web应用。
微服务:
微服务是一种架构风格,它要求我们在开发一个应用的时候,这个应用必须构建成一系列小服务的组合,可以通过http的方式进行互通。
Martin Flower 于 2014 年 3 月 25 日写的《Microservices》,详细的阐述了什么是微服务。
原文地址:http://martinfowler.com/articles/microservices.html
翻译:https://www.cnblogs.com/liuning8023/p/4493156.html

单体应用架构:
单体应用架构是指,我们将一个应用中的所有应用服务都封装在一个应用中。
无论是ERP、CRM或是其他什么系统,都把数据库访问,web访问,等等各个功能放在一个wer包内。

单体应用架构的好处:易于开发和测试;也十分方便部署;当需要扩展时,只需要将war复制多份,然后放到多个服务器上,再做个负载均衡就可以了。
单体应用架构的缺点:哪怕我要修改一个非常小的地方,我都需要停掉整个服务,重新打包、部署这个应用war包。特别是对于一个大型应用,我们不可能吧所有内容都放在一个应用里面,我们如何维护、如何分工合作都是问题。
spring为我们带来了构建大型分布式微服务的全套、全程产品:

构建一个个功能独立的微服务应用单元,可以使用springboot,可以帮我们快速构建一个应用;
大型分布式网络服务的调用,这部分由SpringCloud来完成,实现分布式;
在分布式中间,进行流式数据计算、批处理,我们有spring cloud data flow。
spring为我们想清楚了整个从开始构建应用到大型分布式应用全流程方案。

2.第一个springboot程序

环境配置:

jdk1.8 、 maven3.6.0 、springboot最新版 、idea开发

依赖配置

  1. 导入父工程坐标
<parent>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-parent</artifactId>
 	<version>2.1.3.RELEASE</version>
</parent>

如果我们想要修改SpringBoot项目的jdk版本,只需要简单的添加以下属性即可,如果没有需求,则不添加。

<properties>
  <java.version>1.8</java.version>
</properties>
  1. 添加相应启动器

    web启动器:集成了Tomcat与web的相关配置

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
</dependencies>
所有springboot依赖都是以:`spring-boot-starter-`  开头,后面需要什么依赖就写什么,比如web

SpringBoot将所有的功能场景都抽取出来,做成一个个的starter (启动器),只需要在项目中引入这些starter即可,所有相关的依赖都会导入进来 , 我们要用什么功能就导入什么样的场景启动器即可 ;

单元测试依赖

<!--单元测试-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-test</artifactId>
    <scope>test</scope>
    <exclusions>
        <exclusion>
            <groupId>org.junit.vintage</groupId>
            <artifactId>junit-vintage-engine</artifactId>
        </exclusion>
    </exclusions>
</dependency>

打包发布必须加的依赖

<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
    </plugins>
</build>

若有依赖需要降版本,也需要指定版本号

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.9.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.kuang</groupId>
    <artifactId>springboot-01-helloworld</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>springboot-01-helloworld</name>
    <description>springboot-01-helloworld</description>

    <properties>
        <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>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
    		</exclusions>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

<!--如上所示,主要有四个部分:

项目元数据信息:创建时候输入的Project Metadata部分,也就是Maven项目的基本元素,包括:groupId、artifactId、version、name、description等

parent:继承spring-boot-starter-parent的依赖管理,控制版本与打包等内容

dependencies:项目具体依赖,这里包含了spring-boot-starter-web用于实现HTTP接口(该依赖中包含了Spring MVC),官网对它的描述是:使用Spring MVC构建Web(包括RESTful)应用程序的入门者,使用Tomcat作为默认嵌入式容器。;
spring-boot-starter-test用于编写单元测试的依赖包。
build:构建配置部分。默认使用了spring-boot-maven-plugin,配合spring-boot-starter-parent就可以把Spring Boot应用打包成JAR来直接运行。-->

程序配置

1.编写启动类

注解@SpringBootApplication表明是启动类

2.编写main函数:

@SpringBootApplication
public class Application {
   public static void main(String[] args) {
        SpringApplication.run(Application.class, args);  // args一定要写,否则报无法加载主类
    }
}

在与启动类同级目录下建包:pojo、controller、service、mapper 一定要在同级目录下,否则识别不到

3.编写Controller

@RestController
public class HelloController {
   @GetMapping("hello")
   public String hello(){
        return "hello, spring boot!";
    }
}
@GetMapping 组合注解,是@RequestMapping(method = RequestMethod.GET)的缩写

该注解将HTTP Get 映射到 特定的处理方法上。

即可以使用@GetMapping(value = “/hello”)来代替@RequestMapping(value=”/hello”,method= RequestMethod.GET)。即可以让我们精简代码。

@Configuration:声明一个类作为配置类,代替xml文件

@configuration注解内部被@component组件注解修饰,所以被@configuration修饰的类可以被ioc容器扫描,进行初始化,加载注解@PropertySource(value=”classpath:jdbc.properties”)内的外部资源文件,
对类内的属性进行初始化,再对@Bean注解修饰的方法间接初始化,使用已经初始化的属性值

@Bean:声明在方法上,将方法的返回值加入Bean容器,代替<bean>标签

@Value:属性注入

@value注解注入值只能注入简单类型(普通数值、字符串),不能注入对象类型。所以被放弃使用 

@PropertySource(value=”classpath:jdbc.properties”):指定外部属性文件

springboot banner图标:

springboot banner在线生成工具(https://www.bootschool.net/ascii)

1.复制工具中内容图
2.resources添加banner.txt文件,粘贴内容图

原文地址:https://www.cnblogs.com/leizia/p/15231208.html