springboot的HelloWorld实现(springboot学习笔记01)

1.实现功能介绍

浏览器发送hello请求,服务器接收请求并处理,响应“Hello World!”字符串

2.环境准备

-jdk1.8.0_144
-maven3.3.9
-IntelliJ IDEA 2018.2.4 x64

3.实现过程

3.1 创建一个maven工程(jar)

在这里插入图片描述在这里插入图片描述
在界面右下角选择自动导入依赖
在界面右下角选择自动导入依赖
或者也可在maven工程栏下刷新导入
在这里插入图片描述

3.2 导入spring boot相关的依赖

<parent>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-dependencies</artifactId>
  <version>1.5.9.RELEASE</version>
  <relativePath>../../spring-boot-dependencies</relativePath>
  <dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>
</parent>

3.3 编写一个主程序,用来启动Spring Boot应用

创建名为HelloWorldMainApplication的类,这个类放在com.atpian的包下
创建名为HelloWorldMainApplication的类,这个类放在com.atpian的包下

package com.atpian;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

/**
 *  @SpringBootApplication 标注一个主程序类,说明这是一个Spring Boot应用
 */
@SpringBootApplication
public class HelloWorldMainApplication {

    public static void main(String[] args) {
        
        //让Spring应用启动起来
        SpringApplication.run(HelloWorldMainApplication.class,args);
    }
}

3.4 编写相关的Controller、Service

在com.atpian包下创建HelloController类,这个类放在controller这个类下面
在com.atpian包下创建HelloController类,这个类放在controller这个类下面

package com.atpian.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

//@Controller 用于处理请求
@Controller
public class HelloController {

    //@ResponseBody 用于把"Hello World!"返回给浏览器
    @ResponseBody
    //@RequestMapping 接收来自于浏览器的hello请求
    @RequestMapping("/hello")
    public String hello(){
        //给浏览器返回一串“Hello World!”
        return "Hello World!";
    }
}

4.运行主程序测试

完成上述操作即可直接运行main方法

让浏览器发送一个hello请求:
让浏览器发送一个hello请求

5.简化部署

5.1 把springboot的maven插件导入到pom.xml里面

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

5.2 运行package进行打包

在这里插入图片描述

可以在target目录下看到打包完成后的jar包
在这里插入图片描述

5.3 我们可以将jar包复制出来在cmd用java -jar的命令直接运行

在这里插入图片描述
在这里插入图片描述

6.Hello World探究

6.1 POM文件

6.1.1 父项目

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.5.9.RELEASE</version>
</parent>

他的父项目是

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

他来真正管理springboot应用里面的所有依赖的版本,相当于springboot的版本仲裁中心
以后我们导入依赖默认不需要写版本(除了没有在dependencies里面管理的依赖)

6.1.2 启动器

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>

spring-boot-starter-web: spring-boot是场景启动器,Spring Boot将所有的功能场景都抽取出来,做成一个个的starters(启动器),只需要在项目里面引入这些starter相关场景的所有依赖都会导入进来,要用什么功能就导入什么场景的启动器。spring-boot-starter-web帮我们导入了web模块正常运行所依赖的组件。

6.2 主程序类(主入口类)

**@SpringBootApplication** :即Spring boot应用,它标注在某个类上,说明这个类是SpringBoot的主配置类,SpringBoot就运行这个类的main方法来启动SpringBoot应用,它包含了以下组合注解:
```java
@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 {

其中:
1.@SpringBootConfiguration:Spring Boot的配置类(配置类即配置文件)
用于标注在某个类上,表示其是一个Spring Boot的配置类。@SpringBootConfiguration包含@Configuration这个最底层的spring定义的注解。配置类也是容器中的一个组件。
2.@EnableAutoConfiguration:开启自动配置功能
@EnableAutoConfiguration告诉SpringBoot开启自动配置功能,以前我们需要配置的东西,Spring Boot帮我们自动配置,它又包含:

@AutoConfigurationPackage
@Import(EnableAutoConfigurationImportSelector.class)
public @interface EnableAutoConfiguration {

2.1 @AutoConfigurationPackage:自动配置包,里面含有@Import(AutoConfigurationPackages.Registrar.class)。@Import(AutoConfigurationPackages.Registrar.class)是
Spring的底层注解,它给容器中导入一个组件,导入的组件由AutoConfigurationPackages.Registrar.class决定,包括主配置类(@SpringBootApplication标注的类)的所在包及下面所有子包里面的所有组件。
2.2 @Import(EnableAutoConfigurationImportSelector.class):导入一些组件,这些组件由EnableAutoConfigurationImportSelector.class(导入哪些组件的选择器)决定。选择器通过返回所有的组件的全类名来将组件添加到容器中,最终会给容器导入非常多的自动配置类(xxxAutoConfiguration)(如图),自动配置类给容器导入场景所需要的所有组件并配置好这些组件,有了自动配置类,免去了我们手动编写配置、注入功能组件等的工作。在这里插入图片描述
SpringFactoriesLoader.loadFactoryNames(EnableAutoConfiguration.class,classLoader);
Spring Boot在启动的时候从类路径下的META-INF/spring.factories中获取EnableAutoConfiguration指定的值,将这些值作为自动配置类导入到容器中,自动配置类就生效,帮我们进行自动配置工作;以前我们需要自己配置的东西,自动配置类都帮我们;
J2EE的整体整合解决方案和自动配置都在spring-boot-autoconfigure-1.5.9.RELEASE.jar;

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

IDE都支持使用Spring的项目创建向导快速创建一个Spring Boot项目

7.1 IDEA:

在这里插入图片描述
在这里插入图片描述
选择我们需要的模块,向导会联网创建Spring Boot项目
在这里插入图片描述
在这里插入图片描述
默认生成的Spring Boot文件夹中的目录结构:
1.主程序已经编写好了,我们只需要编写我们自己的逻辑
2.resources文件夹中的目录结构:
static:保存所有的静态资源:js、css、images
templates:保存所有的模板页面(Spring Boot默认jar包使用嵌入式的Tomcat,默认不支持JSP页面),可以使用模板引擎freemarker、thymeleaf
application.properties:Spring Boot应用的配置文件,可以修改一些默认设置

7.2 STS:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值