时间:2021-05-19
我们每做一个新项目,通常都是从另一个项目把代码拷贝过来,然后在其上做开发。但是这种模式的一个比较大的问题就是会有很多上个项目的遗留代码。因此,开发一个公共的应用骨架系统,在开始其他新项目时,从这个骨架系统开始开发,是一个很好的选择。
我们首先需要创建一个SpringBoot工程,我们可以使用:https://start.spring.io/
如下所所:
上图中比较关键的是从页面右侧“Add Dependencies”按钮弹出的列表中选择“Spring Web”。网站上的工具会生成一个基本的SpringBoot工程,并自动将zip文件下载到本地。
将该文件解压,以idea community版本打开(也可以使用商业版,但是该版本是收费版,出于尊重知识产权的原因,使用免费的社区版)。
我们首先将系统自带的src/main/resources下面的application.properties文件删除,添加application.yaml文件,添加如下内容:
server: port: ${port:2208}spring: application: name: first-servicelogging: pattern: console: "%d{HH:mm:ss.SSS} %-5level %logger{36} - %msg%n" file: "%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n" level: org.springframework.web: DEBUG file: app.log下面我们以Person对象的增、删、改、查操作为例,创建一个REST风格的API。
我们首先在repository包中创建Person对象:
接下来我们来创建REST服务端,在controller包中创建DemoController类:
@RestController@RequestMapping("/person")public class DemoController { private List<Person> persons = new ArrayList<>(); @GetMapping public List<Person> findAll() { return persons; } @GetMapping("/{personId}") public Person findById(@PathVariable("personId") Long personId, HttpServletRequest request) { String mode = request.getParameter("mode"); System.out.println("mode=" + mode + "!"); return persons.stream().filter(item -> item.getPersonId().equals(personId)).findFirst().get(); } @PostMapping public Person add(@RequestBody Person p) { p.setPersonId((long)(persons.size()+1)); persons.add(p); return p; } @DeleteMapping("/{personId}") public void delete(@PathVariable("personId") Long personId) { List<Person> ps = persons.stream().filter(item -> item.getPersonId(). equals(personId)).collect(Collectors.toList()); persons.removeAll(ps); } @PutMapping public void update(@RequestBody Person p) { Optional<Person> person = persons.stream().filter(item -> item.getPersonId(). equals(p.getPersonId())).findFirst(); person.ifPresent(po->persons.set(persons.indexOf(po), p)); }}由于用到了Jdk8以后的一些特性,这里稍做一些解释:
我们下面需要对REST服务进行测试,我们可以通过PostMan来进行测试,但是在这里,我们将采用Swagger来进行测试。这样做主要好处是可以同时生成REST服务的文档。
我们首先在项目根目录下的pom.xml中添加如下内容:
同时给应用类StpApplication添加如下标注:
@EnableSwagger2@SpringBootApplicationpublic class StpApplication { ...... @Bean public Docket api() throws IOException, XmlPullParserException { MavenXpp3Reader reader = new MavenXpp3Reader(); Model model = reader.read(new FileReader("pom.xml")); ApiInfoBuilder builder = new ApiInfoBuilder() .title("智慧交通平台") .description("智慧交通平台API接口文档") .version(model.getVersion()) .contact(new Contact("最老程序员", ".zhuanjingkj.stp.demo.controller")) .paths(PathSelectors.any()).build() .apiInfo(builder.build()); }}就是添加@EnableSwagger2标注信息。在浏览器中输入如下地址:http://localhost:2208/swagger-ui.html
会显示如下图所示页面:
我们可以点击进入对应的接口,可以看到接口的调用方法,同时可以填写真实的数据,对接口进行测试。
到此这篇关于SpringCloud应用骨架开发详解的文章就介绍到这了,更多相关SpringCloud应用骨架 内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
1.认为必须要用VisualStudio.NET来开发.NET应用那些对微软.NET开发不了解的人误以为:利用.NET框架开发应用软件时必须要用到VisualS
Webpack是目前基于React和Redux开发的应用的主要打包工具。我想使用Angular2或其他框架开发的应用也有很多在使用Webpack。本节流程如图:
springcloud是一个基于springboot实现的云应用开发工具,它为基于jvm的云应用开发中涉及的配置管理、服务发现、断路器、智能路由、微代理、控制总
SpringCloud是一个基于SpringBoot实现的云应用开发工具,它为基于JVM的云应用开发中的配置管理、服务发现、断路器、智能路由、微代理、控制总线、
这篇文章主要介绍了SpringCloud应用实现配置自动刷新过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以