N年前大学时代想要开发一个Web服务使用的还是SSH框架(struts+spring+hibernate),尤其是Spring这块需要进行大量的配置工作。为了简化应用搭建和开发过程,出现了Sprint Boot这一全新开源框架。
功能更加丰富,性能上更稳定健壮,还提供了大量开箱即用(out-of-the-box)的依赖模块,使用起来更加简单高效,尤其是这几年在互联网微服务的应用上热度很高。
特性
独立的 Spring 应用程序
直接嵌入 Tomcat、Jetty 或 Undertow等容器(无需部署 WAR 文件)
提供 'starter' 核心简化构建配置
尽可能多的自动配置 Spring 和 3rd 方库
提供已集成的产品功能,例如指标、健康检查和外部化配置
完全无需代码生成,无需 XML 配置
Starter
Sprint Boot真正实现了少量配置甚至零配置使用各种组件,它将日常应用研发中的各种场景都抽取出来做成独立的 starter(启动器),使用的时只需要在 Maven 中引入 starter 依赖,SpringBoot 就能自动扫描到要加载的信息并启动相应的默认配置。当然也可以自定义修改配置,除了官方Starter还有第三方技术提供,更可以自己开发。
总之在个人开发体验上来说,在如此简单高效+JAVA语言稳定开发的特性下,对于独立Server的服务应用开发相比Python我更愿意用Spring Boot 框架进行开发,下面就参考官方给出一个Demo实例。开始实践之前还需要注意以下几点:
本篇适合有JAVA语言基础的小白,以前写过Spring Boot项目的可忽略;
系列文章不做技术展开和深入讲解,只做到应用的层面的讲解;
示例和项目开发需要提前搭建好依赖环境;
环境:Java JDK 1.8.x 、Maven 3.x
数据库:Myql 5.7+
IDE:IntelliJ IDEA / Eclipse
搭建一个API项目
项目创建初始化一个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;
@RestController
public 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是一个复合注释,包含以下内容:
@Configuration: 将类标记为应用程序上下文的 bean 源。
@EnableAutoConfiguration:告诉 Spring Boot 根据类路径设置、其他 bean 和各种属性设置开始添加 bean。例如,如果spring-webmvc位于类路径上,则此注释将应用程序标记为 Web 应用程序并激活关键行为,例如设置DispatcherServlet.
@ComponentScan: 开启自动扫描功能,告诉 Spring 在包中查的组件、配置和服务等。
其中 main()
方法使用 Spring Boot 的SpringApplication.run()方法来启动应用程序。
接口测试
重新执行 mvnw spring-boot:run
或 IDEA 运行按钮,编译重启服务,通过PostMan做个接口带参请求测试。
测试结果如图,正确按照预期给予返回结果。
至此一个简单的后端服务就搞定了,你学会了吗?如果着急想提前恶补 JAVA Spring Boot 知识的,推荐一个专项学习导航网站,最后希望你学过后有所收获,未来不断成长,喜欢就多多支持实战原创吧!
文末卑微的博主薅个羊毛,就是邀请体验语雀APP,双方获得3月VIP体验,其实也是经过多个笔记和在线文档实际体验对比后,真心推荐比较好用的一款总结文章&记笔记的好工具,现在也终于推出了APP版本,更可以随时随地记灵感和随记了。
邀请码:NE8YGN
打开语雀App,进入【我】-【活动福利】-【输入邀请码】,领取会员
推荐学习
Spring Boot 学习导航 http://springboot.fun/
资料参考
[1] https://spring.io/guides/gs/rest-service/
[2] http://www.ityouknow.com/spring-boot.html
往期推荐
转载:请关注后后台回复或者私信联系
原创最大的鼓励是点赞 在看让更多人看到