功能:浏览器发送 sayHello 请求,服务器接受请求并处理,响应 Hello。
<groupId>com.seagetech</groupId> <artifactId>springboot-helloworld</artifactId> <version>1.0.0</version>
在官网找到相应的下载地址(官网地址: https://spring.io/projects )或者直接使用如下地址下载: https://docs.spring.io/spring-boot/docs/2.1.0.RELEASE/reference/pdf/spring-boot-reference.pdf 。文档名称 “spring-boot-reference.pdf”,版本2.10.RELEASE。
Part II. Getting Started > 11. Developing Your First Spring Boot Application。
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.1.0.RELEASE</version> </parent>
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> </dependencies>
创建一个主程序类,类名随便取。因为我们是做一个 HelloWorld 的项目,所有我们创建一个 HelloWorldApplication 类:
/** * @auther wangzb * @date 2018/11/9 21:32 */ @Controller @EnableAutoConfiguration public class HelloWorldApplication { @RequestMapping(value = "/sayHello") @ResponseBody public String sayHello(String name){ return "Hello," + name; } public static void main(String[] args) { SpringApplication.run(HelloWorldApplication.class, args); } }
启动 main 方法后,查看 SpringBoot 启动日志:
. ____ _ __ _ _ /// / ___'_ __ _ _(_)_ __ __ _ / / / / ( ( )/___ | '_ | '_| | '_ // _` | / / / / /// ___)| |_)| | | | | || (_| | ) ) ) ) ' |____| .__|_| |_|_| |_/__, | / / / / =========|_|==============|___/=/_/_/_/ :: Spring Boot :: (v2.1.0.RELEASE) ....... . . . ....... . . . (log output here) ....... . . . ... Tomcat started on port(s): 8080 (http) with context path '' ... Started HelloWorldApplication in 3.577 seconds (JVM running for 4.446)
可以看到Tomcat的启动日志:
Tomcat started on port(s): 8080 (http) with context path ”
即,Tomcat 默认启动端口为 8080,项目根路径为 “”,所以在浏览器或者 Postman 中输入地址: http://localhost:8080/sayHello ?name=wangzb,浏览器或Postman响应:
Hello,wangzb
要创建一个可执行 jar,我们需要将 spring-boot-maven-plugin 添加到我们的 pom.xml 中。 在dependencies部分下面插入以下几行:
<build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build>
接下来就可以打包,在 Idea 中点击 package,执行打包命令,之后我们在项目的 target 包下就可以看到刚打包好的 springboot-helloworld-1.0.0.jar 包。在包的路径下,打开 CMD 命令行,执行如下命令:
$ java -jar springboot-helloworld-1.0.0.jar . ____ _ __ _ _ /// / ___'_ __ _ _(_)_ __ __ _ / / / / ( ( )/___ | '_ | '_| | '_ // _` | / / / / /// ___)| |_)| | | | | || (_| | ) ) ) ) ' |____| .__|_| |_|_| |_/__, | / / / / =========|_|==============|___/=/_/_/_/ :: Spring Boot :: (v2.1.0.RELEASE) ....... . . . ....... . . . (log output here) ....... . . . ........ Started Example in 2.536 seconds (JVM running for 2.864)
要退出应用程序,请按 Ctrl+c 或者直接关闭命令窗口,再次在浏览器中访问上面地址,发现链接已不能再访问,如果在 Linux 系统中,且要后台长期运行,可以在命令后加&符号,即:
java -jar springboot-helloworld-1.0.0.jar &
通过 2.1 的讲解,我们熟悉了如何快速创建 SpringBoot 项目。接下来分析 SpringBoot 项目结构,上节中创建好的 SpringBoot 项目结构如下:
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.1.0.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent>
按住Ctrl,点击 spring-boot-starter-parent 进入 spring-boot-starter-parent 项目,它的父项目是:
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-dependencies</artifactId> <version>2.1.0.RELEASE</version> <relativePath>../../spring-boot-dependencies</relativePath> </parent>
如上,可以看到 spring-boot-dependencies。它是真正管理 SpringBoot 项目所有依赖版本,是 Spring Boot 的版本仲裁中心,以后我们导入依赖默认是不需要写版本(没有在 dependencies 里面管理的依赖自然需要声明版本号)。
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency>
spring-boot-starter:spring-boot 场景启动器。帮我们导入了 W eb 模块正常运行所依赖的组件。Spring Boot 将所有的功能场景都抽取出来,做成许多启动器(starter),只需要在项目里面引入这些启动器,相关场景的所有依赖都会导入进来。要用什么功能就导入什么场景的启动器。
更多请参考 “spring-boot-reference.pdf” 2.1.0.RELEASE,13.5节Starters。
如下表所示:
打开2.1节创建的 springboot-demo 项目,找到 SpringBootDemoApplication 类:
package com.seagetech.springbootdemo; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class SpringbootDemoApplication { public static void main(String[] args) { SpringApplication.run(SpringbootDemoApplication.class, args); } }
基本和1.3.3节创建的主程序类一样,main 方法加注解的形式,不同的是,Idea 创建的主程序类使用的是 @SpringBootApplication 注解,它是 SpringBoot 的核心注解,也是一个组合注解,打开这个注解,源码如下:
@Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) @Documented @Inherited @SpringBootConfiguration @EnableAutoConfiguration @ComponentScan
@SpringBootApplication 注解的核心功能其实是:@SpringBootConfiguration、@EnableAutoConfigration、@ComponentScan 三个注解提供。有关这几个注解的详解,请阅读 Spring Boot 系列二:SpringBoot自动配置原理 。