02. 初识spring boot

本文介绍了使用IDEA创建Spring Boot项目的详细步骤,包括选择Spring Initializr、添加JDK、填写项目信息、选择Maven工程、勾选依赖等。还说明了除编译器运行外,项目的另外两种启动方式:命令行和打成jar包运行,最后完成首个Spring Boot项目。

使用IDEA创建spring boot项目

  1. 新建工程,选择Spring Initializr
    这里写图片描述
    如果没有SDK,则需要点击”New”添加JDK1.8,点击Next
    此步骤也可以直接到https://start.spring.io/ 上创建工程,IDEA只是简化了该操作
    这里写图片描述
    填写项目信息,选择maven工程,点击Next
    这里写图片描述
    这里的依赖只勾选Web,Spring boot保留默认版本,点击Next
    这里写图片描述
    填写项目路径,点击Finish
    这里写图片描述
    工程已创建完成,不需要添加额外的依赖

  2. 添加hello world输出
    在com.example.demo下新建一个controller类

package com.example.demo;


import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class HelloWorldController {

    @RequestMapping("/hello")
    public String hello() {
        return "Hello World!";
    }
}

运行DemoApplication.java

/opt/install/java/jdk1.8.0_131/bin/java -XX:TieredStopAtLevel=1 -noverify -Dspring.output.ansi.enabled=always -Dcom.sun.management.jmxremote -Dcom.sun.management.jmxremote.port=36645 -Dcom.sun.management.jmxremote.authenticate=false -Dcom.sun.management.jmxremote.ssl=false -Djava.rmi.server.hostname=localhost -Dspring.liveBeansView.mbeanDomain -Dspring.application.admin.enabled=true -javaagent:/opt/install/idea-IU-182.4129.33/lib/idea_rt.jar=44997:/opt/install/idea-IU-182.4129.33/bin -Dfile.encoding=UTF-8 -classpath /opt/install/java/jdk1.8.0_131/jre/lib/charsets.jar:/opt/install/java/jdk1.8.0_131/jre/lib/deploy.jar:/opt/install/java/jdk1.8.0_131/jre/lib/ext/cldrdata.jar:/opt/install/java/jdk1.8.0_131/jre/lib/ext/dnsns.jar:/opt/install/java/jdk1.8.0_131/jre/lib/ext/jaccess.jar:/opt/install/java/jdk1.8.0_131/jre/lib/ext/jfxrt.jar:/opt/install/java/jdk1.8.0_131/jre/lib/ext/localedata.jar:/opt/install/java/jdk1.8.0_131/jre/lib/ext/nashorn.jar:/opt/install/java/jdk1.8.0_131/jre/lib/ext/sunec.jar:/opt/install/java/jdk1.8.0_131/jre/lib/ext/sunjce_provider.jar:/opt/install/java/jdk1.8.0_131/jre/lib/ext/sunpkcs11.jar:/opt/install/java/jdk1.8.0_131/jre/lib/ext/zipfs.jar:/opt/install/java/jdk1.8.0_131/jre/lib/javaws.jar:/opt/install/java/jdk1.8.0_131/jre/lib/jce.jar:/opt/install/java/jdk1.8.0_131/jre/lib/jfr.jar:/opt/install/java/jdk1.8.0_131/jre/lib/jfxswt.jar:/opt/install/java/jdk1.8.0_131/jre/lib/jsse.jar:/opt/install/java/jdk1.8.0_131/jre/lib/management-agent.jar:/opt/install/java/jdk1.8.0_131/jre/lib/plugin.jar:/opt/install/java/jdk1.8.0_131/jre/lib/resources.jar:/opt/install/java/jdk1.8.0_131/jre/lib/rt.jar:/home/yyhe/idea-workspace/target/classes:/home/yyhe/.m2/repository/org/springframework/boot/spring-boot-starter-web/2.0.4.RELEASE/spring-boot-starter-web-2.0.4.RELEASE.jar:/home/yyhe/.m2/repository/org/springframework/boot/spring-boot-starter/2.0.4.RELEASE/spring-boot-starter-2.0.4.RELEASE.jar:/home/yyhe/.m2/repository/org/springframework/boot/spring-boot/2.0.4.RELEASE/spring-boot-2.0.4.RELEASE.jar:/home/yyhe/.m2/repository/org/springframework/boot/spring-boot-autoconfigure/2.0.4.RELEASE/spring-boot-autoconfigure-2.0.4.RELEASE.jar:/home/yyhe/.m2/repository/org/springframework/boot/spring-boot-starter-logging/2.0.4.RELEASE/spring-boot-starter-logging-2.0.4.RELEASE.jar:/home/yyhe/.m2/repository/ch/qos/logback/logback-classic/1.2.3/logback-classic-1.2.3.jar:/home/yyhe/.m2/repository/ch/qos/logback/logback-core/1.2.3/logback-core-1.2.3.jar:/home/yyhe/.m2/repository/org/apache/logging/log4j/log4j-to-slf4j/2.10.0/log4j-to-slf4j-2.10.0.jar:/home/yyhe/.m2/repository/org/apache/logging/log4j/log4j-api/2.10.0/log4j-api-2.10.0.jar:/home/yyhe/.m2/repository/org/slf4j/jul-to-slf4j/1.7.25/jul-to-slf4j-1.7.25.jar:/home/yyhe/.m2/repository/javax/annotation/javax.annotation-api/1.3.2/javax.annotation-api-1.3.2.jar:/home/yyhe/.m2/repository/org/yaml/snakeyaml/1.19/snakeyaml-1.19.jar:/home/yyhe/.m2/repository/org/springframework/boot/spring-boot-starter-json/2.0.4.RELEASE/spring-boot-starter-json-2.0.4.RELEASE.jar:/home/yyhe/.m2/repository/com/fasterxml/jackson/core/jackson-databind/2.9.6/jackson-databind-2.9.6.jar:/home/yyhe/.m2/repository/com/fasterxml/jackson/core/jackson-annotations/2.9.0/jackson-annotations-2.9.0.jar:/home/yyhe/.m2/repository/com/fasterxml/jackson/core/jackson-core/2.9.6/jackson-core-2.9.6.jar:/home/yyhe/.m2/repository/com/fasterxml/jackson/datatype/jackson-datatype-jdk8/2.9.6/jackson-datatype-jdk8-2.9.6.jar:/home/yyhe/.m2/repository/com/fasterxml/jackson/datatype/jackson-datatype-jsr310/2.9.6/jackson-datatype-jsr310-2.9.6.jar:/home/yyhe/.m2/repository/com/fasterxml/jackson/module/jackson-module-parameter-names/2.9.6/jackson-module-parameter-names-2.9.6.jar:/home/yyhe/.m2/repository/org/springframework/boot/spring-boot-starter-tomcat/2.0.4.RELEASE/spring-boot-starter-tomcat-2.0.4.RELEASE.jar:/home/yyhe/.m2/repository/org/apache/tomcat/embed/tomcat-embed-core/8.5.32/tomcat-embed-core-8.5.32.jar:/home/yyhe/.m2/repository/org/apache/tomcat/embed/tomcat-embed-el/8.5.32/tomcat-embed-el-8.5.32.jar:/home/yyhe/.m2/repository/org/apache/tomcat/embed/tomcat-embed-websocket/8.5.32/tomcat-embed-websocket-8.5.32.jar:/home/yyhe/.m2/repository/org/hibernate/validator/hibernate-validator/6.0.11.Final/hibernate-validator-6.0.11.Final.jar:/home/yyhe/.m2/repository/javax/validation/validation-api/2.0.1.Final/validation-api-2.0.1.Final.jar:/home/yyhe/.m2/repository/org/jboss/logging/jboss-logging/3.3.2.Final/jboss-logging-3.3.2.Final.jar:/home/yyhe/.m2/repository/com/fasterxml/classmate/1.3.4/classmate-1.3.4.jar:/home/yyhe/.m2/repository/org/springframework/spring-web/5.0.8.RELEASE/spring-web-5.0.8.RELEASE.jar:/home/yyhe/.m2/repository/org/springframework/spring-beans/5.0.8.RELEASE/spring-beans-5.0.8.RELEASE.jar:/home/yyhe/.m2/repository/org/springframework/spring-webmvc/5.0.8.RELEASE/spring-webmvc-5.0.8.RELEASE.jar:/home/yyhe/.m2/repository/org/springframework/spring-aop/5.0.8.RELEASE/spring-aop-5.0.8.RELEASE.jar:/home/yyhe/.m2/repository/org/springframework/spring-context/5.0.8.RELEASE/spring-context-5.0.8.RELEASE.jar:/home/yyhe/.m2/repository/org/springframework/spring-expression/5.0.8.RELEASE/spring-expression-5.0.8.RELEASE.jar:/home/yyhe/.m2/repository/org/slf4j/slf4j-api/1.7.25/slf4j-api-1.7.25.jar:/home/yyhe/.m2/repository/org/springframework/spring-core/5.0.8.RELEASE/spring-core-5.0.8.RELEASE.jar:/home/yyhe/.m2/repository/org/springframework/spring-jcl/5.0.8.RELEASE/spring-jcl-5.0.8.RELEASE.jar com.example.demo.DemoApplication

  .   ____          _            __ _ _
 /\\ / ___'_ __ _ _(_)_ __  __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
 \\/  ___)| |_)| | | | | || (_| |  ) ) ) )
  '  |____| .__|_| |_|_| |_\__, | / / / /
 =========|_|==============|___/=/_/_/_/
 :: Spring Boot ::        (v2.0.4.RELEASE)

2018-08-26 21:04:10.504  INFO 8176 --- [           main] com.example.demo.DemoApplication         : Starting DemoApplication on yyhe-ThinkPad-L450 with PID 8176 (/home/yyhe/idea-workspace/target/classes started by yyhe in /home/yyhe/idea-workspace)
2018-08-26 21:04:10.506  INFO 8176 --- [           main] com.example.demo.DemoApplication         : No active profile set, falling back to default profiles: default
2018-08-26 21:04:10.559  INFO 8176 --- [           main] ConfigServletWebServerApplicationContext : Refreshing org.springframework.boot.web.servlet.context.AnnotationConfigServletWebServerApplicationContext@1d76aeea: startup date [Sun Aug 26 21:04:10 CST 2018]; root of context hierarchy
2018-08-26 21:04:11.923  INFO 8176 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat initialized with port(s): 8080 (http)
2018-08-26 21:04:11.945  INFO 8176 --- [           main] o.apache.catalina.core.StandardService   : Starting service [Tomcat]
2018-08-26 21:04:11.945  INFO 8176 --- [           main] org.apache.catalina.core.StandardEngine  : Starting Servlet Engine: Apache Tomcat/8.5.32
2018-08-26 21:04:11.949  INFO 8176 --- [ost-startStop-1] o.a.catalina.core.AprLifecycleListener   : The APR based Apache Tomcat Native library which allows optimal performance in production environments was not found on the java.library.path: [/usr/java/packages/lib/amd64:/usr/lib64:/lib64:/lib:/usr/lib]
2018-08-26 21:04:12.021  INFO 8176 --- [ost-startStop-1] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring embedded WebApplicationContext
2018-08-26 21:04:12.022  INFO 8176 --- [ost-startStop-1] o.s.web.context.ContextLoader            : Root WebApplicationContext: initialization completed in 1467 ms
2018-08-26 21:04:12.082  INFO 8176 --- [ost-startStop-1] o.s.b.w.servlet.ServletRegistrationBean  : Servlet dispatcherServlet mapped to [/]
2018-08-26 21:04:12.086  INFO 8176 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean   : Mapping filter: 'characterEncodingFilter' to: [/*]
2018-08-26 21:04:12.087  INFO 8176 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean   : Mapping filter: 'hiddenHttpMethodFilter' to: [/*]
2018-08-26 21:04:12.087  INFO 8176 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean   : Mapping filter: 'httpPutFormContentFilter' to: [/*]
2018-08-26 21:04:12.088  INFO 8176 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean   : Mapping filter: 'requestContextFilter' to: [/*]
2018-08-26 21:04:12.293  INFO 8176 --- [           main] o.s.w.s.handler.SimpleUrlHandlerMapping  : Mapped URL path [/**/favicon.ico] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler]
2018-08-26 21:04:12.546  INFO 8176 --- [           main] s.w.s.m.m.a.RequestMappingHandlerAdapter : Looking for @ControllerAdvice: org.springframework.boot.web.servlet.context.AnnotationConfigServletWebServerApplicationContext@1d76aeea: startup date [Sun Aug 26 21:04:10 CST 2018]; root of context hierarchy
2018-08-26 21:04:12.599  INFO 8176 --- [           main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/hello]}" onto public java.lang.String com.example.demo.HelloWorldController.hello()
2018-08-26 21:04:12.606  INFO 8176 --- [           main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error],produces=[text/html]}" onto public org.springframework.web.servlet.ModelAndView org.springframework.boot.autoconfigure.web.servlet.error.BasicErrorController.errorHtml(javax.servlet.http.HttpServletRequest,javax.servlet.http.HttpServletResponse)
2018-08-26 21:04:12.607  INFO 8176 --- [           main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error]}" onto public org.springframework.http.ResponseEntity<java.util.Map<java.lang.String, java.lang.Object>> org.springframework.boot.autoconfigure.web.servlet.error.BasicErrorController.error(javax.servlet.http.HttpServletRequest)
2018-08-26 21:04:12.639  INFO 8176 --- [           main] o.s.w.s.handler.SimpleUrlHandlerMapping  : Mapped URL path [/webjars/**] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler]
2018-08-26 21:04:12.640  INFO 8176 --- [           main] o.s.w.s.handler.SimpleUrlHandlerMapping  : Mapped URL path [/**] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler]
2018-08-26 21:04:12.752  INFO 8176 --- [           main] o.s.j.e.a.AnnotationMBeanExporter        : Registering beans for JMX exposure on startup
2018-08-26 21:04:12.781  INFO 8176 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat started on port(s): 8080 (http) with context path ''
2018-08-26 21:04:12.785  INFO 8176 --- [           main] com.example.demo.DemoApplication         : Started DemoApplication in 2.664 seconds (JVM running for 3.294)

以上是从编译器中运行的,下面将说明另外两种启动方式
1. 命令行

yyhe@yyhe-ThinkPad-L450:~$ cd idea-workspace/
yyhe@yyhe-ThinkPad-L450:~/idea-workspace$ mvn spring-boot:run

2. 打成jar包运行

yyhe@yyhe-ThinkPad-L450:~/idea-workspace$ mvn clean package
yyhe@yyhe-ThinkPad-L450:~/idea-workspace$ java -jar target/demo-0.0.1-SNAPSHOT.jar

打开浏览器,输入http://localhost:8080/hello 看到如下画面
这里写图片描述

到此,第一个spring boot项目已经完成。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值