springboot(一)hello world

1、SpringBoot入门Demo

(1)打开命令窗口,执行如下命令,一路回车即可
mvn archetype:generate -DgroupId=com.qzc -DartifactId=springboot_demo -DarchetypeArtifactId=maven-archetype-quickstart
(2)将Maven项目导入IDEA
(3)修改Maven项目的pom.xml文件。官方文档中推荐我们继承官方的一个父工程spring-boot-starter-parent(当然也可以不继承,官方文档也给出了方案),如果进入spring-boot-starter-parent的pom文件中,可以看到,其中提供了一些可配置文件的扫描路径、大量的插件以及常用的UTF-8编码,这些可以算是一个最佳实践。我们需要搭建一个web项目,因此在pom文件中,添加spring-boot-starter-web的依赖。
(4)编写代码。将文档中的如下代码写入(Ctrl C+Ctrl V)。
  这里需要注意其中的几个注解,@RestController和@RequestMapping是SpringMVC中的注解,在此不做说明。@EnableAutoConfiguration是SpringBoot提供的一个注解,SpringBoot根据这个注解和我们在pom文件中添加的依赖(spring-boot-starter-*),智能的对我们的Spring环境进行配置,例如我们在pom中添加了spring-boot-starter-web的依赖,SpringBoot则会自动为我们进行web环境的配置(如添加内置Tomcat、配置SpringMVC等)。
  另外,我们使用运行main方法的方式来启动工程,这也就意味着我们可以在main方法中添加一些自己的逻辑,来扩展项目的启动流程,具体扩展点在官方文档也进行了指明,我会在后续的文章中进行分享。
-------------------------------------------------------------------------------
@RestController
@EnableAutoConfiguration
public class Example {
@RequestMapping("/")
String home() {
return "Hello World!";
}
public static void main(String[] args) throws Exception {
SpringApplication.run(Example.class, args);
}
}
---------------------------------------------------------------------------
(5)直接运行main方法,控制台打印如下信息
(6)在浏览器输入http://localhost:8080/,即可看到Hello World

2、SpringBoot运行方式

  通常我们在做JavaWeb项目时,是将项目打包成war包,然后丢到容器中运行,容器会将war包解压成对应的文件夹。SpringBoot由于可以自带Servlet容器,因此可以将我们的项目打成可执行的jar包运行。
  我们知道jar包通常分为可执行的jar包和普通的jar包。可执行的jar包可以一次打包到处运行(只要有JVM),因为它已经把所有依赖都包含进去了;普通的jar包则没法运行,因为它只有自己的原始逻辑,因此通常是作为提供功能的第三方。
  为了将项目打包成可执行的jar,SpringBoot提供了一个maven插件(当然,我们也可以通过IDE来打出可执行的jar,但当我们的代码要上生产环境时,需要通过自动化构建来打包,这时IDE的打包方式就不行了)。在pom文件中添加如下
------------------------------------------------------------------------------------------
org.springframework.boot
spring-boot-maven-plugin
-----------------------------------------------------------------------------------------------------
再代开命令行窗口到项目路径下,执行 mvn package 命令。
此时在项目路径下的target文件夹就生成了一个可执行的jar
到该jar所在路径下,执行java -jar命令即可将项目运行起来

3、构建SpringBoot项目注意事项

(1)通常新建的SpringBoot项目会继承spring-boot-starter-parent,进入到spring-boot-starter-parent的pom文件看下
  spring-boot-starter-parent的pom文件中指定默认的JDK版本是1.6,如果我们想要使用其他版本的jdk,例如JDK1.8,需要在我们自己的pom中添加如下
------------------------------------------------------
1.8
-----------------------------------------------------------------
  此外,在spring-boot-starter-parent的pom文件中为我们指定了一些配置文件的路径,这些在我们真实项目中配置一些必要的信息(如数据库)有很大的作用。
(2)有时我们的新建项目由于一些原因,不想继承spring-boot-starter-parent,这时就需要我们自己去添加配置项以继续使用Spring Boot 提供的依赖管理,添加如下
-----------------------------------------------------------------------------------------
org.springframework.boot
spring-boot-dependencies
1.5.13.RELEASE
pom
import
---------------------------------------------------------------------------------------------------
 我们也可以自己制定某些依赖包的版本,例如我们可以自己制定SpringMVC的版本
type默认是jar, 可以改成war ,这两种比较常用;
这里我们说下pom,当需要引入很多依赖的时候,pom.xml文件会过大,我们可以通过依赖一个父项目来解决这个问题,但也可能导致父项目pom.xml文件过大,所以最终的方法是type改成pom方式,即把很多jar包打包到一个pom中,我们依赖了pom,就可以下载所有的jar包。
scope控制 dependency 元素的使用范围
compile(默认)
如果没有指定scope,那么该元素的默认值为compile。被依赖项目需要参与到项目的编译、测试、打包、运行等阶段,打包时通常会包含被依赖项目,是比较强的依赖。
provided
被依赖项目理论上可以参与到项目的编译、测试、运行等阶段,当时在打包时进行了exclude动作。
应用场景:例如我们在开发一个web项目,在编译的时候我们需要依赖servlet-api.jar,但在运行时我们不需要这个jar,因为它已由应用服务器提供,这是我们就需要用provided来修饰这个依赖包。
runtime
顾名思义,表示该依赖项目无需参与到项目的编译,但会参与到测试与运行阶段。
应用场景:例如在编译时我们不需要JDBC API的jar,但在运行时才需要JDBC的驱动包。
test
表示该依赖项目仅会参与到项目的测试阶段。
应用场景:例如,Junit 测试。
system
与provided类似,但是被依赖项不会从maven仓库查找依赖,而是从本地系统中获取,systemPath元素用于指定依赖在系统中jar的路径。
-------------------------------------------------------------------------------------------
com.cjf
auth-center
1.5
system
${basedir}/MyContent/WEB-INF/lib/auth-center.jar
-----------------------------------------------------------------------------------------------------
import
它只使用在dependencyManagement中,我们知道maven和java只能单继承,作用是管理依赖包的版本,一般用来保持当前项目的所有依赖版本统一。
例如:项目中有很多的子项目,并且都需要保持依赖版本的统一,以前的做法是创建一个父类来管理依赖的版本,所有的子类继承自父类,这样就会导致父项目的pom.xml非常大,而且子项目不能再继承其他项目。
import为我们解决了这个问题,可以把dependencyManagement放到一个专门用来管理依赖版本的pom中,然后在需要用到该依赖配置的pom中使用scope import就可以引用配置。