SpringBoot 第一篇:HelloWorld 跑起来

背景

      金融行业从业快十年,作为银行系开发人员来说开源框架了解不多非常正常,因为银行系的运行平台,基本上不会采购小厂商集合开源框架自建的产品,竞标的产品没有几十个成功案例,你也进不了这个门槛(有关系的除外,这个内幕都不说了 )。所以大多数开发人员(我不是大多数,得意.jpg)在银行系接触的更多的是各大金融行业服务商自己的产品,这些产品里面也集成有像Spring、SpringBoot之类的框架,当然,你一个应用开发人员只需要写写业务逻辑,底层平台实现是接触不到的,会用就行了。

     平时工作也比较忙,每天客户的需求要分析、要讨论、要设计、要开发、要测试、要上线,相信做金融这行的人都明白,996虽然网上炒得不可开交,反正我们真的都是常态(心平气和.jpg),真的就是这么无限循环,哪有多余的时间给你研究这些网上的五花八门的框架(休假除外)。

      最近来了新人,啥都不太懂,又和我咨询SpringBoot框架的事,我也没实际弄过,了解的都是一点概念上的东西,心想怕给人教坏了所以来实操一下,顺便给人实际指导一下。

环境

开发工具: IntelliJ IDEA 2019.1.4  (不要跟我提Eclipse一样好用,不接受,用了你才有资格来讨论)

基础环境: jre 1.8.0_211

Maven:apache-maven-3.6.1

SpringBoot:2.1.7.RELEASE 目前最新的正式版

开发之前你要做的是

1、下载IDEA,并安装好,并注册。度娘帮你搞定

2、下载Maven对应的版本放到本地目录,然后IDEA配置 File-> Settings –> Build,Execution –> Maven ,修改 User settings file 里面为自己的maven配置文件。初期可以选择默认,我是由于用到了自己的私服所以有修改的必要性,有需要看私服的戳我之前的 Nexus3.0搭建私服上传JAR包

开发步骤

1、新建项目 Create New Project,选择 Spring Initializr –> 选择SDK 这里选择在你电脑上安装的JDK,如果没有显示则选择下图的2来添加自己的JDK目录,点击 Next 。

SpringBoot 第一篇:HelloWorld 跑起来_第1张图片


2、主要是填写建立项目的相关资料,根据自己的实际需求来填,点击Next 。

SpringBoot 第一篇:HelloWorld 跑起来_第2张图片

3、选择Web- > Spring Web Starter, 这是通过SpringBoot建立WEB项目的模式。

SpringBoot 第一篇:HelloWorld 跑起来_第3张图片

4、Next之后输入项目名称,这个项目名称就是最终显示在你左侧导航里面的项目名。这里保持不动。直接点击 Finish 。

SpringBoot 第一篇:HelloWorld 跑起来_第4张图片

查看下 pom.xml 文件内容,都是默认的,项目自动都给你配置好了:

xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0modelVersion>
    <parent>
        <groupId>org.springframework.bootgroupId>
        <artifactId>spring-boot-starter-parentartifactId>
        <version>2.1.7.RELEASEversion>
        <relativePath/> 
    parent>
    <groupId>com.mmgroupId>
    <artifactId>workartifactId>
    <version>0.0.1-SNAPSHOTversion>
    <name>workname>
    <description>First Project for Spring Bootdescription>

    <properties>
        <java.version>1.8java.version>
    properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.bootgroupId>
            <artifactId>spring-boot-starter-webartifactId>
        dependency>

        <dependency>
            <groupId>org.springframework.bootgroupId>
            <artifactId>spring-boot-starter-testartifactId>
            <scope>testscope>
        dependency>
    dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.bootgroupId>
                <artifactId>spring-boot-maven-pluginartifactId>
            plugin>
        plugins>
    build>

project>


5、项目建立完成后,在com.mm.work包下新建 controller 包,新建一个类 HelloWorld如下:

package com.mm.work.controller;

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

@RestController
public class HelloWorld {
    @RequestMapping("/")
    public String test(){
        return "Hello World!";
    }
}


6、直接运行项目。

SpringBoot 第一篇:HelloWorld 跑起来_第5张图片

有没有发现一些情况?web项目我的中间件没有咋启动了,web.xml没配置,Spring 没配置 ,全部都不需要配置了。

看启动日志能看到一些情况:

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

2019-08-08 11:14:04.343  INFO 10172 --- [           main] com.mm.work.WorkApplication              : Starting WorkApplication on Locus with PID 10172 (E:\Workspaces\work\target\classes started by Locus in E:\Workspaces\work)
2019-08-08 11:14:04.347  INFO 10172 --- [           main] com.mm.work.WorkApplication              : No active profile set, falling back to default profiles: default
2019-08-08 11:14:05.162  INFO 10172 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat initialized with port(s): 8080 (http)
2019-08-08 11:14:05.178  INFO 10172 --- [           main] o.apache.catalina.core.StandardService   : Starting service [Tomcat]
2019-08-08 11:14:05.178  INFO 10172 --- [           main] org.apache.catalina.core.StandardEngine  : Starting Servlet engine: [Apache Tomcat/9.0.22]
2019-08-08 11:14:05.267  INFO 10172 --- [           main] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring embedded WebApplicationContext
2019-08-08 11:14:05.267  INFO 10172 --- [           main] o.s.web.context.ContextLoader            : Root WebApplicationContext: initialization completed in 870 ms
2019-08-08 11:14:05.400  INFO 10172 --- [           main] o.s.s.concurrent.ThreadPoolTaskExecutor  : Initializing ExecutorService 'applicationTaskExecutor'
2019-08-08 11:14:05.524  INFO 10172 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat started on port(s): 8080 (http) with context path ''
2019-08-08 11:14:05.529  INFO 10172 --- [           main] com.mm.work.WorkApplication              : Started WorkApplication in 1.628 seconds (JVM running for 2.565)
2019-08-08 11:14:13.708  INFO 10172 --- [nio-8080-exec-1] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring DispatcherServlet 'dispatcherServlet'
2019-08-08 11:14:13.709  INFO 10172 --- [nio-8080-exec-1] o.s.web.servlet.DispatcherServlet        : Initializing Servlet 'dispatcherServlet'
2019-08-08 11:14:13.714  INFO 10172 --- [nio-8080-exec-1] o.s.web.servlet.DispatcherServlet        : Completed initialization in 5 ms

系统启动时自动全部给你做了,方便开发人员更需要关注的是业务逻辑而不是各种环境配置。

打开页面访问:http://localhost:8080/,项目就完成了。

image

单元测试

项目过程中很多自己单独的业务逻辑需要测试,每次通过修改-重启项目-验证-再次修改-再次重启项目验证会严重影响单元测试进度。

项目的test包下有SpringBoot自动生成的测试类可以用来验证自己的业务逻辑调用。

你可能感兴趣的:(SpringBoot 第一篇:HelloWorld 跑起来)