HelloWorldExample 中的第1个注解 @RestController 是一个被熟知的原型注解(stereotype
annotation),它是一个类级别的注解,作用于整个类(的所有方法),不能单独用于某个方法上。大家都知道 @Controller 被用于处理 web 请求,比如例子中的 HelloWorldExample 类,而 @RestController 则是告诉 Spring 把对于该类中的所有请求的响应结果字符串直接返回给调用者。
注解 @RequestMapping 提供了路由信息,简单点说就是 HTTP 访问的 URL 路径,而 / 对应的 home 方法。
@RestController 和 @RequestMapping 都是 Spring MVC 中的注解。
@EnableAutoConfiguration 是第2个类级别的注解,用于告知如何装配 Spring。例子中的的 spring-boot-starter-web 添加了 Tomcat 和 Spring MVC,意味着这是一个 web 工程。
Auto-configuration 可以很好地与 Starters 协作,但是两者并没有直接关联,不使用 Starters 也能自动配置。
main 方法是 Java 应用的入口。例子中的 main 方法通过调用 SpringApplication 的 run 方法来委托给 Spring Boot 的 SpringApplication 类。 SpringApplication 引导我们的应用程序,启动 Spring ,而 Spring 又会启动自动配置的 Tomcat web 服务器。我们需要传递 Example.class 作为 run 方法的参数来告诉 SpringApplication 哪个是主 Spring 组件。而 args 用于传递命令行的参数
Java 没有提供加载嵌套 jar 文件(jar 文件本身包含在一个 jar 中)的标准方法。因此按照正常的方式,如果希望发布一个自包含的应用程序,这可能会有问题。
为了解决这个问题,许多开发人员使用“uber”jar。uber jar 将应用程序的所有依赖中的所有类打包到一个单独的归档中。这种方法的问题是很难看出应用程序中有哪些类库。如果在多个 jar 中使用相同的文件名(但内容不同),也可能会出现问题。
Spring Boot 采用了一种不同的方法,允许直接嵌套 jar。pom.xml 中用了 spring-boot-maven-plugin 用于打包创建可执行的 jar。例子中使用了 spring-boot-starter-parent ,包含了用于 repackage goal 的 <executions> 配置。
<build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build>
以上便是一个最基本的 Spring Boot 应用会涉及到的概念和配置。
Spring Boot2(003):简要回顾“HelloWorld” web 工程
原文:https://www.cnblogs.com/wpbxin/p/11809387.html