Spring Boot - HelloWorld

4. Spring Boot - HelloWorld

功能

浏览器发送Hello请求,服务器接受请求并处理,响应HelloWorld字符串

步骤

  1. 创建maven工程

    image-20201207203224676 image-20201207203351540 image-20201207203510133 image-20201207203910024

    maven工程创建完成

  2. 导入SpringBoot相关依赖

    <parent>
            <artifactId>spring-boot-starter-parent</artifactId>
            <groupId>org.springframework.boot</groupId>
            <version>2.3.4.RELEASE</version>
        </parent>
    
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
    </dependencies>
    
  3. 编写主程序,启动应用

    package com.why;
    
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    
    /**
     * @Description TODO 启动SpringBoot应用
     * @Author why
     * @Date 2020/12/7 20:50
     * Version 1.0
     **/
    @SpringBootApplication//标注这是一个SpringBoot应用
    public class HelloWorldMainApplication {
        public static void main(String[] args) {
            //Spring应用启动起来
            SpringApplication.run(HelloWorldMainApplication.class,args);
        }
    }
    
  4. 编写相关的Controller和Service

    package com.why.controller;
    
    import org.springframework.stereotype.Controller;
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.ResponseBody;
    
    /**
     * @Description TODO Controller
     * @Author why
     * @Date 2020/12/7 20:57
     * Version 1.0
     **/
    @Controller //标识为一个controller
    public class HelloController {
    
        @ResponseBody //返回的结果直接写入 HTTP 响应正文中,一般在异步获取数据时使用
        @RequestMapping("/hello") //处理请求地址映射
        public String hello(){
            return "Hello World!";
        }
    }
    
  5. 运行HelloWorldMainApplication.java的主方法

    image-20201207210400782
  6. 通过访问http://localhost:8080/hello

    image-20201207210454568

  7. 简化部署

    pom.xml添加配置

    <build>
            <plugins>
    <!--            这个插件将springboot应用打包成一个可执行的jar包-->
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                    <version>2.3.4.RELEASE</version>
                </plugin>
            </plugins>
        </build>
    

    点击打包

在这里插入图片描述

打包好的jar包再target目录下

在这里插入图片描述

  1. Java -jar启动jar包

    在这里插入图片描述

5. Hello World探究

5.1 pom.xml文件
5.1.1 父项目
<parent>
    <artifactId>spring-boot-starter-parent</artifactId>
    <groupId>org.springframework.boot</groupId>
    <version>2.3.4.RELEASE</version>
</parent>

它的父项目是:

<parent>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-dependencies</artifactId>
  <version>2.3.4.RELEASE</version>
</parent>

它来真正管理Spring Boot应用里面的所有依赖版本

导入依赖默认不需要写版本(没有再dependencies里面的依赖需要声明版本号)

5.1.2 启动器
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>

spring-boot-starter-web:

spring-boot-starter:spring-boot场景启动器;帮我们导入了web模块正常运行所依赖的组件;

Spring Boot将所有的功能场景都抽取出来,做成一个个的starters(启动器),只需要在项目里面引入这些starter 相关场景的所有依赖都会导入进来。要用什么功能就导入什么场景的启动器

5.2 主程序类
@SpringBootApplication//标注这是一个SpringBoot应用
public class HelloWorldMainApplication {
    public static void main(String[] args) {
        //Spring应用启动起来
        SpringApplication.run(HelloWorldMainApplication.class,args);
    }
}

@SpringBootApplication: Spring Boot应用

标注在某个类上说明这个类是SpringBoot的主配置类,SpringBoot 就应该运行这个类的main方法来启动SpringBoot应用;

这是一个混合注解,由以下注解组成:

@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan(
    excludeFilters = {@Filter(
    type = FilterType.CUSTOM,
    classes = {TypeExcludeFilter.class}
), @Filter(
    type = FilterType.CUSTOM,
    classes = {AutoConfigurationExcludeFilter.class}
)}
)
public @interface SpringBootApplication {

**@SpringBootConfiguration:**Spring Boot配置类

  • 标注在某个类上,表示这是一个Spring Boot配置类

  • **@Configuration:**配置类上标注这个注解

    配置类 - - - - - - 配置文件;配置类也是容器中的一个组件:@Component

**@EnableAutoConfiguration:**开启自动配置功能

  • 以前需要配置的东西,Spring Boot帮我们自动配置

  • @EnableAutoConfiguration告诉Spring Boot开启自动配置;这样配置才能生效

  • @AutoConfigurationPackage
    @Import({AutoConfigurationImportSelector.class})
    public @interface EnableAutoConfiguration {
    

    @AutoConfigurationPackage:自动配置包

    @Import({Registrar.class})
    

    Spring的底层注解@Import,给容器中导入一个组件,导入的组件由Registrar.class

    将主配置类(@SpringBootApplication标注的类)的所在包及所有子包里面的所有组件扫描到Spring容器中

  • **@Import({AutoConfigurationImportSelector.class}):**导入哪些组件的选择器

    public String[] selectImports(AnnotationMetadata annotationMetadata) {
    

    导入的组件以全类名的方式返回,这些组件添加到容器中

    会给容器中导入非常多的自动配置类(xxxAutoConfguration)就是给容器中导入这个场景需要的所有组件,并配置好这些组件

    有了 自动配置类,免去手动编写配置注入功能等组件

  • SpringFactoriesLoader.loadFactoryNames(EnableAutoConfiguration.class,classLoader);

    **Spring Boot在启动的时候从类路径下的META-INF/spring.factories中获取EnableAutoConfiguration指定的值,将 这些值作为自动配置类导入到容器中,自动配置类就生效,帮我们进行自动配置工作;**以前我们需要自己配置的东 西,自动配置类都帮我们;

    J2EE的整体整合解决方案和自动配置都在spring-boot-autoconfigure-2.3.4.RELEASE.jar;

6. 使用Spring Initializer快速创建Spring Boot项目

使用Spring Initializer,选择JDK版本

image-20201208200953553

写组织id,项目名

image-20201208201526389

选择模块

image-20201208201727710

设置文件路径

image-20201208201831909

此过程需要连接网络,否则无法创建

6.1 遇到的问题

image-20201208202828402

如果Java显示灰色不是代码文件夹,要去file —>project structure下设置

image-20201208203108913

许多在Java下无法建包 new pacage也是由于这个原因

6.2 文件目录结构

image-20201208203250866

默认生成的Spring Boot项目;

  • 主程序已经生成好了,我们只需要我们自己的逻辑
  • resources文件夹中目录结构
    1. static:保存所有的静态资源; js css images;
    2. templates:保存所有的模板页面;(Spring Boot默认jar包使用嵌入式的Tomcat,默认不支持JSP页 面);可以使用模板引擎(freemarker、thymeleaf);
  • application.properties:Spring Boot应用的配置文件;可以修改一些默认设置;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值