用 Spring Boot 实现电商系统 Web API (一)Hello World

我们先从 Hello World! 开始。

一、构建工具

假设已经装好 Java SDK 8 。

安装构建工具

我们选用 gradle 来构建项目。

https://gradle.org/install 这个网页会告诉你如何安装。

我们也可以选择手动安装,先从 https://gradle.org/releases 下载案装包。

image

当前最新版是 v4.0,我们就下载这个版本,点 “complete”,是一个ZIP包,下载完成后解压到任意目录即可。

解压后,目录中文件如下

image

我们还需要将  bin 目录放到环境变量中,我当前用的是 Windows 10 系统,gradle 的 bin 目录是 “D:\JavaEE\gradle-4.0\bin”,可以放到系统变量后者用户变量的“PATH”中,如下

image

然后打开控制台,输入命令 “gradle -v”,如果显示如下图,说明 gradle 安装成功。

image

 

二、新建Spring Boot 项目

在任意目录下新建一个名为“spring-hello”目录并进入到目录中,名字任取,

mkdir spring-hello && cd spring-hello

创建一个名为 build.gradle 的文本文件,

cd . > build.gradle

创建目录 src\main\java\com\hang 并进入到目录中

mkdir src\main\java\com\hang && cd src\main\java\com\hang

在目录 src\main\java\com\hang 创建Java源文件 App.java

cd . > App.java

在目录 src\main\java\com\hang 下新建 controller 目录并进入到  controller 目录

mkdir controller && cd controller

创建名为 HelloController.java的源文件

cd . > HelloController.java

最后目录结构如下

image

目录 src\main\java 用来放Java源码,必须这样命名。com\hang 是Java的包名,com\hang\controller 也是包名,只要符合Java的包名规范即可,没有特定要求。

 

三、开始编码

用记事本或者任何其他文本编辑器打开 App.java,输入以下内容

package com.hang;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class App {
    public static void main(String[] args){
        SpringApplication.run(App.class, args);
    }
}

在 HelloController.java输入以下内容:

package com.hang.controller;

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

@RestController
public class HelloController {
    @GetMapping("/")
    public String hello(){
        return "Hello World!";
    }
}

在 build.gradle  输入以下内容

buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        classpath("org.springframework.boot:spring-boot-gradle-plugin:1.5.4.RELEASE")
    }
}

apply plugin: 'java'
apply plugin: 'org.springframework.boot'

repositories {
    jcenter()
}

dependencies {
    compile 'org.springframework.boot:spring-boot-starter-web'
}

 

四、编译

我们先编译下项目,在 spring-hello 目录中执行命令

gradle build

这个编译过程要花点时间,因为 Gradle 要到网上下载依赖库。

如果出现下图信息,说明编译成功

image

 

五、运行

到这,我们就可以开始运行项目了,执行命令

gradle bootRun

控制台会打出如下图信息

image

“Tomcat started on port(s): 8080 (http)”这一句说我们的 Spring Boot 程序使用的是 8080 端口,

“Started App in 2.132 seconds (JVM running for 2.4)” 这一句说明我的Spring Boot 程序已经启动成功了。

打开浏览器,输入 http://localhost:8080/

image

如果出现 “ Hello World!”说明我们的程序已经能正确运行。

 

六、简要说明

6.1 build.gradle

build.gradle 是构建配置文件,用的是 groovy 语言。gradle就是根据build.gradle来构建我们的Spring Boot项目的。

gradle本身是不知道如何构建Spring Boot程序的,但gradle支持插件,所以我们引入Spring Boot的Gradle插件,就可以构建Spring Boot程序了。

buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        classpath("org.springframework.boot:spring-boot-gradle-plugin:1.5.4.RELEASE")
    }
}

以上代码就是引入Spring Boot的Gradle插件,名叫“spring-boot-gradle-plugin”,版本是“1.5.4.RELEASE”,repositories {jcenter()}是告诉Gradle去jcenter库找这个插件,jcenter库在https://bintray.com/bintray/jcenter,国内访问有些慢。只有加入了这个 buildscript后,下边的apply plugin: 'org.springframework.boot' 这一句才能起作用。

apply plugin: 'java'

表示使用 Java插件,我们是用Java写的,需要这个插件,Java插件是Gradle的内置插件,所以可以直接使用。

apply plugin: 'org.springframework.boot'

使用 org.springframework.boot这个插件来构建和运行我们的Spring Boot程序,由于这个插件不是Gradle内置的插件,所以要先在 buildscript中引入,前文已经提到。上文我们运行Spring Boot程序用到的命令“gradle bootRun”也是来自于这个插件。

repositories {
    jcenter()
}
dependencies {
    compile 'org.springframework.boot:spring-boot-starter-web'
}

上面的代码意思是,我们的程序要依赖“spring-boot-starter-web”这个库,这个库要从jcenter下载。

至此,build.gradle文件已经解释完。也许有人会问,怎么就知道用 “gradle bootRun”来运行程序呢,大家可以在项目目录下执行

gradle tasks

Gradle是基于任务的,这个命令就是列出当前项目中支持的任务。

image

注意红框内,第一条任务就是“bootRun”,所以我们可以通过“gradle bootRun”这一句运行我们的Spring Boot程序。

6.2 App.java

由于 Spring Boot 就是一个 Java 应用程序,所以我们的先写一个程序入口 main 函数,和正常的 Java 程序的 main 函数没有什么区别。

SpringApplication.run(App.class, args);

这个语句表示直接启动 Spring 应用。

最重要的是“@SpringBootApplication” 这个注解,Spring Boot 把 Sping 以前很复杂的 XML 配置用注解来实现,完全自动化的配置。这个注解会自动地去加载配置,这个注解中还包含了一个扫描子包 Controller 的动作,会自动扫描子包,并完成配置。

6.3 HelloController.java

@RestController
public class HelloController {
    @GetMapping("/")
    public String hello(){
        return "Hello World!";
    }
}

HelloController.java 很简单,只有几行代码。

@RestController 表示这个一个Restful API,

@GetMapper 注解表示一个 Get 请求,如果有 Get 请求访问根目录,比如我们在浏览器中输入“http://localhost:8080/”就执行hello()函数,函数直接返回“Hello World!”。类似的请求还有:@PostMapper, @PutMapper, DeleteMapper,分别对应着HTTP协议的POST、PUT、DELETE三个请求方法。

七、附录

源码 https://github.com/jinghang/commerce/tree/master/0x01/java-demo 

posted @ 2017-07-03 10:56  teafree  阅读(4356)  评论(0编辑  收藏  举报