第一个Spring Rest应用

1 创建Marven工程

         (1)新建Marven工程

             可以使用https://start.spring.io/ 网站来快速的生成一个spring boot的模板程序,包含了spring boot的基本结构或者使用下        面的新建工程向导

 

       选择新建工程的Marven选项,archetype可以选择默认点击下一步


springboot reids前缀 resin springboot_spring

      设置下项目的GroupID,ArtifactID,Version 

      

springboot reids前缀 resin springboot_SpringBoot_02

      (2)工程结构

       工程结构图如下,工程目录主要包括src程序目录,resources 资源目录其中在资源目录中新建application.properties程序默认配置文件,pom.xml 配置依赖的库文件 由于使用了maven 保持src下main和test的目录结构

springboot reids前缀 resin springboot_spring_03

springboot reids前缀 resin springboot_springboot reids前缀_04

 2   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.0</modelVersion>

    <groupId>com.hisense</groupId>
    <artifactId>SpringbootPractice1</artifactId>
    <version>1.0-SNAPSHOT</version>

    <!--先加载父模块pom的配置 -->
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.3.RELEASE</version>
    </parent>

   <!--spring-boot-starter-web添加了Tomcat和Spring MVC -->
   <!-- - spring-boot-starter 模板:核心模块,包括自动配置支持、日志和YAML
     - spring-boot-starter-web 模块:web模块-->
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>com.jayway.jsonpath</groupId>
            <artifactId>json-path</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>


    <!--定义属性可以在任何位置使用${java.version} 的方式的到值1.8-->
    <properties>
        <java.version>1.8</java.version>
    </properties>
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

    <repositories>
        <repository>
            <id>spring-releases</id>
            <url>https://repo.spring.io/libs-release</url>
        </repository>
    </repositories>
    <pluginRepositories>
        <pluginRepository>
            <id>spring-releases</id>
            <url>https://repo.spring.io/libs-release</url>
        </pluginRepository>
    </pluginRepositories>

</project>

     spring-boot-starter-web添加了Tomcat和Spring MVC 
     spring-boot-starter 模板:核心模块,包括自动配置支持、日志和YAML
     spring-boot-starter-web 模块:web模块

 

对于copy过来的pom.xml依赖文件,默认系统不会再自动下载需要的类库,点击idea->视图->工具窗口->marven工程菜单打开marven Project 窗口,点击刷新按钮便可下载依赖的库文件

springboot reids前缀 resin springboot_SpringBoot_05

   

2 创建访问控制器

       在src目录中创建文件GreetingController.java ,作为web访问的资源控制器处理get请求, @RestController 注解类表明此类实现SpringBoot的web rest访问功能,类中的Greeting函数使用了注解 @RequestMapping("/greeting") 代表可以使用 “网址/greeting” 的形式访问此函数,返回的类Greeting 会被SpringBoot自动序列号为json字符串返回给调用者。

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

import java.util.concurrent.atomic.AtomicLong;

@RestController
public class GreetingController {

    private static final String template = "Hello, %s!";
    private final AtomicLong counter = new AtomicLong();

    @RequestMapping("/greeting")
    public Greeting greeting(@RequestParam(value="name", defaultValue="World") String name) {

        return new Greeting(counter.incrementAndGet(),
                String.format(template, name));
    }
}

    Greeting函数没有明确GET vs. PUTPOST ,所有的对/greeting的请求都会进入此方法,因为@RequestMapping 映射所有的http操作, 可以使用@RequestMapping(method=GET)  to 明确get映射

@RestController注解 等价于 @Controller+@ResponseBody 将返回值已json形式返回

Spring’s MappingJackson2HttpMessageConverter 会自动被选择 转换 Greeting到JSON.

  其中使用的Greeting类定义为

package hisense;
public class Greeting {
    private final long id;
    private final String content;

    public Greeting(long id, String content) {
        this.id = id;
        this.content = content;
    }

    public long getId() {
        return id;
    }

    public String getContent() {
        return content;
    }
}

3 浏览器测试

    在src目录下创建HelloBoot.java 程序入口类

 注意:Application启动类文件一定要放在包的最外侧,而且必须放在包下面,不允许直接的根目录,从application路径下可以搜索到所有的子包 
 原因:spring-boot会自动加载启动类所在包下及其子包下的所有组件.例如一下的结构

springboot reids前缀 resin springboot_springboot reids前缀_06

package hisense;

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

@SpringBootApplication
public class HelloBoot {

    public static void main(String[] args) {
        SpringApplication.run(HelloBoot.class, args);

    }
}

@SpringBootApplication注解类方便的自动添加了下面所有的注解:

  • @Configuration  tags the class as a source of bean definitions for the application context.
  • @EnableAutoConfiguration tells Spring Boot to start adding beans based on classpath settings, other beans, and various property settings.
  • Normally you would add @EnableWebMvc for a Spring MVC app, but Spring Boot adds it automatically when it sees spring-webmvc on the classpath. This flags the application as a web application and activates key behaviors such as setting up a DispatcherServlet.
  • @ComponentScan tells Spring to look for other components, configurations, and services in the hello package, allowing it to find the controllers.

运行程序后

  在浏览器三种输入localhost:8080/greeting 或者 http://localhost:8080/greeting?name=User 使用get 请求访问rest接口 /greeting,在访问网址中可以带用name参数

  可以看到如下结果

{"id":1,"content":"Hello, World!"}

4 修改内置Web服务器的端口

 

    修改application.properties

      我们只需要在在资源文件夹resources内创建 application.properties配置文件

      在里面加入    server.port=8004

server.port=8081

  这样便可以使用localhost:8004/greeting来进行访问了。