微信搜索【大奇测试开】,关注这个坚持分享测试开发干货的家伙。

在N年前的大学时代想要开发一个Web服务使用的还是SSH框架(struts+spring+hibernate)尤其是Spring这块需要进行大量的配置工作,为了简化应用搭建和开发过程出现了Sprint Boot全新开源框架,且功能更加丰富,性能上更加稳定健壮,还提供了大量开箱即用(out-of-the-box)的依赖模块,使用起来更加简单高效,尤其是这几年在互联网微服务的应用上热度很高。
Sprint Boot真正少量配置甚至零配置使用各种组件的核心,它将日常应用研发中的各种场景都抽取出来做成独立的 starter(启动器),使用的时只需要在 Maven 中引入 starter 依赖,SpringBoot 就能自动扫描到要加载的信息并启动相应的默认配置。当然也可以自定义修改配置,除了官方Starter还有第三方技术提供,更可以自己开发。
总之在个人开发体验上来说,在如此简单高效+JAVA语言稳定开发的特性下,对于独立Server的服务应用开发相比Python我更愿意用Spring Boot 框架进行开发,下面就参考官方给出一个Demo实例。
不过开始实践之前还需要注意以下几点:
初始化一个Spring Boot 应用两种方式,官方 和 IDE
方式一:官方初始化项目包
Step1. 通过访问 https://start.spring.io/ 选择开发选项和添加依赖包一键生成应用包。

注意本地JDK装的是1.8.X版本,所有Java的选项需要改成8,然后点击GENERATE就会自动下载一个按照选项配置生成的项目包。
Step2. 解压到某路径下,打开IDEA导入项目,选择到 pom.xml -> Open As Project -> Trust Project 导入包后等待maven依赖下加载完成。

方式二:IDEA创建Sprint Boot
新建一个项目(如果IDEA是最新版,请在上一个项目中File->Close project 才会进入到项目管理窗口),New Project -> Spring Initializr 选项内容如图所示。

下一步Next 选择版本和添加依赖,点击Finish完成创建。

最终两种方式都会创建出如下的结构的 Spring Boot 应用项目

目录结构说明
|-/src/mian/java 主开发代码和程序入口
|-/src/mian/resources 配置或静态文件资源区
|-/src/mian/resources/application.properties默认属性配置文件
|-/src/test 测试代码和测试初始化入口
|-pom.xml应用Maven等配置文件
依赖包说明
spring-boot-starter-web 开发Web应用的模块spring-boot-starter-actuator 程序监控器模块spring-boot-starter-test 默认引用 测试模块 如JUnitspring-boot-starter 默认引用核心模块,如果引用了starter-web此依赖自动包含在其中,可以不在项目中显示引用。 实际开发中还会为创建不同模式的目录结构比如MVC,其他的依赖包添加也都会像图中选中部分一样方式随时添加即可。
项目运行
依赖全部初始化完成后,其实暂时不需要编写任何代码就能运行,直接点击IDEA的工具栏Run或Debug按钮。

或通过 Terminal 执行 Maven命令行运行应用。
mvnw spring-boot:run
因为一开始添加了监控依赖包,所以可以直接访问这个接口 http://localhost:8080/actuator 看到一些可访问的接口,选择 /health 健康检查看下服务状态为 UP 服务正常。
接下来开发第一个自己的接口,在 /src/mian/java 先创建个资源返回类 HelloEntity.java用于JSON格式的数据返回,code 表示状态码,content表示内容。
package com.daqi.ideademo;public class HelloEntity { private Integer code; private String content; public HelloEntity(Integer code, String content) { this.code = code; this.content = content; } public long getCode() { return code; } public String getContent() { return content; }}
再创建一个控制器类,用于实现API Web服务,识别处理HTTP请求通过 @RestController(包含@Controller和@ResponseBody )注解标记为控制类,通过@GetMapping 注解标记GET方法请求,并给定一个接口路径。
package com.daqi.ideademo;import org.springframework.web.bind.annotation.GetMapping;import org.springframework.web.bind.annotation.RequestParam;import org.springframework.web.bind.annotation.RestController;@RestControllerpublic class HelloController { @GetMapping("/api/sayHello") public HelloEntity sayHello(@RequestParam(value = "content") String content){ String respContent = "你好,".concat(content); return new HelloEntity(200, respContent); }}@RequestParam指定了一个接口请求Params参数,sayHello代码中返回code=200,content=格式化接收参数的内容字符串。
以上内容不必过多纠结,后边的分享中在用到的时候都会进行讲解,这块内容照着做有个整体印象即可

在运行程序之前先对入口程序做个简单解释说明
@SpringBootApplication是一个复合注释,包含以下内容:
其中 main() 方法使用 Spring Boot 的SpringApplication.run()方法来启动应用程序。
接口测试
重新执行 mvnw spring-boot:run或 IDEA 运行按钮,编译重启服务,通过PostMan做个接口带参请求测试。

测试结果如图,正确按照预期给予返回结果。
至此一个简单的后端服务就搞定了,你学会了吗?如果着急想提前恶补 JAVA Spring Boot 知识的,推荐一个专项学习导航网站,最后希望你学过后有所收获,未来不断成长,喜欢就多多支持实战原创吧!
推荐学习
Spring Boot 学习导航 http://springboot.fun/
资料参考
[1] https://spring.io/guides/gs/rest-service/
[2] http://www.ityouknow.com/spring-boot.html
关于后续更多进展和分享欢迎持续关注公众号或博客。
本文来自博客园,作者:MrZ大奇,转载请注明原文链接:https://www.cnblogs.com/mrzcode/p/15998390.html