- 使用 Spring Initializr 创建 Spring Boot 应用程序
- 在Spring Boot中配置Cassandra
- 在 Spring Boot 上配置 Tomcat 连接池
- 将Camel消息路由到嵌入WildFly的Artemis上
声明:不用 idea 只是因为我想试试别的环境能不能一样起来,太复杂的配置和优化、惯例写法我不会,我并不是专业 SpringBoot 后台开发。
装好 vscode,装好 spring 插件、java 插件
jdk要求:11 及以上(插件不认8了)
插件列表
Debugger for Java
Dependency Analytics
Language Support for Java(TM) by Red Hat
Lombok Annotations Support for VS Code (这个之后会说明)
Maven for Java
Project Manager for Java
Red Hat Commons
Spring Boot Dashboard
Spring Boot Extension Pack
Spring Boot Tools
Spring Initializr Java Support
Ctrl
+ Shift
+ P
快捷键搜索 spring,创建 maven 工程
然后选择 maven 版本(默认即可,标SNAPSHOT是不稳定版)
然后选择语言(默认 Java)
然后填 Group Id(假定我的域名是 sukiruga.cn,那么就填 cn.sukiruga):
然后填 Artifact Id(随便,小写单词即可)
发布的格式,默认 jar 包:
选择 Java 版本(我选了与本机一致的 11):
选择依赖项:
lombok 是一个好用的包,通过注解少写很多代码,具体自己查,如果不选,后续要在 pom 文件中自己加 lombok 的依赖。
如果是老手,你知道要做鉴权,要连数据库,那你可以翻到下面自己找想要的依赖点选即可,最后回车完成创建,会让你选一个文件夹存放生成的项目有关文件:
随后插件会下载依赖,并提示创建成功,点击 Open 即可在新的 vscode 窗口打开:
插件还会提示,这是个 java 工程,是否导入:
选 yes 即可。
src/main/java
目录即写代码的地方,按上面的步骤来看,这个目录下应该会有这样层级的目录:
cn/sukiruga/api
,并且在这个 api
文件夹下会有一个主程序入口类的文件 ApiApplication.java
。
这个命名是大驼峰,跟 Artifact Id 是一样的,后面接 Application 尾缀。
假如 Artifact Id 是 demo
,那么这个入口主程序文件的名称将是 DemoApplication.java
。
在 cn/sukiruga/api
下创建一个 Student 类,路径如下:cn/sukiruga/api/models/Student.java
package cn.sukiruga.api.models;
import lombok.AllArgsConstructor;
import lombok.Data;
@Data
@AllArgsConstructor
public class Student {
private long id;
private String name;
private int age;
}
这两个注解即 lombok 提供的,可以少写很多 getter、setter 等常用函数和常用全参数构造函数。lombok 有很多这种注解,网上资料不少,需要自己查。
这个类的实例代表的就是一条数据,对应关系数据库表里的一个记录(一行)。
在 cn/sukiruga/api
下创建一个接口 repository/IStudentContext.java
,我习惯了 ASP.NET 的写法和称呼,这边抄过来用了,你也可以写 repository/StudentRepository.java
,对应待会的实现类即 StudentRepositoryImpl.java
,我这里待会的实现类即 repository/impl/StudentContext.java
。
接口用来表示依赖:
package cn.sukiruga.api.repository;
import java.util.Collection;
import cn.sukiruga.api.models.Student;
public interface IStudentContext {
public Collection<Student> getAll();
public Student getOne(long id);
public void createOrUpdate(Student student);
public void delete(long id);
}
Springboot 会根据对应类的注解 @Repository
将它注入程序内部:
package cn.sukiruga.api.repository.impl;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import org.springframework.stereotype.Repository;
import cn.sukiruga.api.models.Student;
import cn.sukiruga.api.repository.IStudentContext;
@Repository
public class StudentContext implements IStudentContext {
private static Map<Long, Student> virtualDatabase;
static {
virtualDatabase = new HashMap<>();
virtualDatabase.put(1L, new Student(1L, "张三", 21));
}
@Override
public Collection<Student> getAll() {
return virtualDatabase.values();
}
@Override
public Student getOne(long id) {
return virtualDatabase.get(id);
}
@Override
public void createOrUpdate(Student student) {
virtualDatabase.put(student.getId(), student);
}
@Override
public void delete(long id) {
virtualDatabase.remove(id);
}
}
cn.sukiruga.world.repository
包下的接口、实现类,表示某个对应的 model 能具备什么行为,在某个具体的 repository 实现类下,你可以定制不同的链接数据库的方式,或者像本例一样,用 HashMap
代替数据库作为示例程序。
SpringBoot
认 @Repository
这个注解。
repository 表示能怎么样对数据库、数据来源进行怎么样的操作,而下文的 controller 则不对数据库,它拥有一个 repository 成员变量,对外暴露访问接口。
这样,repository 对内,controller 对外,分工明确。
创建于 cn/sukiruga/api/controller/StudentController.java
,对应包名即 cn.sukiruga.api.controller
package cn.sukiruga.api.controller;
import java.util.Collection;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import cn.sukiruga.api.models.Student;
import cn.sukiruga.api.repository.impl.StudentContext;
@RestController
@RequestMapping("/student")
public class StudentController {
// 自动将 StudentContext 对象注入
@Autowired
private StudentContext context;
@GetMapping
public Collection<Student> getAll() {
return context.getAll();
}
@GetMapping("/{id}")
public Student getOne(@PathVariable("id") long id) {
return context.getOne(id);
}
@PostMapping
public void save(@RequestBody Student student) {
context.createOrUpdate(student);
}
@PutMapping
public void update(@RequestBody Student student) {
context.createOrUpdate(student);
}
@DeleteMapping("/{id}")
public void delete(@PathVariable long id) {
context.delete(id);
}
}
这有一堆注解,对应的功能也笔记好认:
@RestController
:指明这个控制器是 REST
风格控制器@RequestMapping
:指明这个控制器对应的路由,此处参数是 "/student"
@GetMapping
:这个注解表示此方法处理当前控制器 get 请求,可带参数,见代码中带 "/{id}"
的方法@PostMapping
:这个注解表示此方法处理当前控制器 post 请求@PutMapping
:这个注解表示此方法处理当前控制器的 put 请求@DeleteMapping
:这个注解表示此方法处理当前控制器的 delete 请求,可带参数@PathVariable
:这个注解表示参数是请求 url 中的 queryString 动态参数,例如代码中的 id@RequestBody
:这个注解表示会把请求体中的 json(springboot 默认序列化和反序列化 json)反序列化为 Student 类对象这里几个简单的增删改查方法,利用了 context 成员变量,就不需要在这个类里操心数据是从哪来的了。
对应接口如下:
api | 方法 | 参数 |
---|---|---|
/student |
GET | 无参则返回 json 数组,全体 student 数据 |
/student/{id} |
GET | 有参则查询某个 student |
/student |
POST | 一个 json 对象,字段使用小驼峰,表示创建一条记录 |
/student |
PUT | 一个 json 对象,字段使用小驼峰,表示更新一条记录 |
/student/{id} |
DELETE | 删除对应 id 的记录 |
SpringBoot 本来就提倡少配置、无配置,不过这东西也不能绝对没有,尽量减少它的书写即可。
它的配置文件名必须是 application
起头,至于命名规则和不同后缀名的优先级和书写格式则可以自行寻找博客。
例如:https://www.jianshu.com/p/a0b3147bc4de
本文使用 yml 格式。
创建项目时,插件在 src/main/resources
目录下(也必须是这个目录)创建了一个 application.properties
文件,将其改为 application.yml
,并使用 yaml 格式指明启动端口(端口随你指定):
server:
port: 2351
关于 yml 和 properties 格式的切换,百度搜索“maven application.properties 和 yml”能搜到很多博客。
在这就说个经验好了:如果之前使用了 properties 文件运行过,现在转用 yml,要清理一次 maven -X clean install
再运行。
properties 文件存在则 yml 文件失效。
vscode 装完准备章节的插件后,在侧栏会有如下面板:
JAVA PROJECT
面板比较全,其中 {}
图标表示是一个包。此截图中最顶级的 api
图标,有三条小竖线,代表是一个项目。右键 api
层级可以点击 Run
进行运行调试,也可以点 api
层级最右侧的三角箭头按钮运行项目。
MAVEN
面板则比较简单,下一节的打包成 jar 则要用到这里的右键菜单 - package 命令。
SPRING BOOT DASHBORAD
面板则针对 SpringBoot 项目,它能识别出 Java 项目中的 SpringBoot 框架程序,你除了在 JAVA PROJECT
面板中运行外,也可以在这里运行。
启动项目后,可以在控制台看到消息:
端口也是改了之后的端口。
可使用 vscode 插件 Thunder Client
或者 postman 软件进行接口测试:
在 MAVEN
面板右键执行 package
命令,在项目根目录下的 target
文件夹会生成 <Artifact Id>-<version>-<SNAPSHOT/RELEASE>.jar
包:
然后,你就可以拷这个文件到有 Java 环境的系统运行啦,运行命令是:
java -jar /path/to/api-0.0.1-SNAPSHOT.jar
Windows 考虑使用 WinSW 程序制作 Windows 服务;
Linux 使用 Systemctl 程序制作 service。
需要自己在 pom 包中添加 parent 依赖和 dependencies 依赖(包括 springboot 有关的依赖和 lombok 依赖),
除了上面写的源代码外,还需要手动写一个第 2 节中提到的入口主程序类,类似 C# ASP.NET 中的 Program 类。
我对编程真的很陌生,并且在理解 RESTful API 的概念时遇到了一些麻烦。我读过 REST 和 RESTful API。我已经查看了 SO 中已经提出的问题,但似乎无法更好地理解该主题。 在我的
我以为我知道REST /“RESTFul”,restfulservices,webservices,SOA和微服务是什么,但是我遇到了许多不同的定义,我得出的结论是这些术语被过度使用,滥用或完全错误定
我有一个列表,其中有一个“人员和组”列。当我使用 REST 查询行时,我会在此列中列出用户 ID。 我发现这篇文章将帮助我将每个 id 转换为标题 http://www.codeproject.com
我想问一些关于 REST 调用的问题。我是 REST 调用的绿色,我想了解什么是 REST 调用以及如何使用 URL 向服务器发送 REST 调用。谁能给我一些基本的教程或链接供我引用? 另外,如果我
很难说出这里问的是什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或言辞激烈,无法以目前的形式合理回答。如需帮助澄清此问题以便可以重新打开,visit the help center . 8年前关闭
如果有一个 REST 资源我想监视来自其他客户端的更改或修改,那么最好(也是最 RESTful)的方法是什么? 我这样做的一个想法是通过提供特定资源来保持连接打开,而不是在资源不(尚)存在时立即返回。
我有一个可以返回大量项目的 RESTful API,我希望能够使用分页样式技术来限制项目数量,这是 RESTful API 中的一个好主意吗? 如果有可能最好通过链接(在这种情况下为 url)或请求正
我仍然处于适应以 REST 方式做事的过程中。 在我的情况下,客户端软件将与 RESTful 服务交互。很少,客户端会上传其整个实体数据库(每个实体序列化为大约 5kb 的 xml 块)。 也许我错了
设计一个路径解析可能有歧义的 REST API 是否被认为是不好的做法?例如: GET /animals/{id} // Returns the animal with the given ID
我知道 REST 并且知道在不使用 session 的情况下创建 RESTful Web 服务,我更了解它,但我不太了解无状态的概念以及使用 REST 如何使您的应用程序可扩展 有人可以解释 REST
我正在尝试找到解决以下问题的最佳方法:我们的应用程序是SaaS,它支持Web登录的SAML。该应用程序还公开了应该在自动化和无人值守的流程中使用的REST API,这意味着没有交互式用户可以键入凭据。
由于 REST 是无状态的,因此传入的每个请求都不知道传入的前一个请求。在这种情况下是否可以使用连接池? 如果要实现连接池,它将像标准数据库连接一样在每个请求时打开连接池并关闭它。 如何实现 REST
得墨忒耳定律(真的应该是得墨忒耳的建议)说你不应该“穿过”一个物体去接触它们的子物体。如果您作为客户需要执行一些重要的操作,大多数情况下您使用的域模型应该支持该操作。 REST 原则上是一个愚蠢的对象
我唯一真正接触到 REST 的想法已经通过 Ruby on Rails 的 RESTful routing .这非常适合我使用 Rails 构建的基于 CRUD 的应用程序,但因此我对 RESTful
有什么好处 http://www.example.com/app/servlet/cat1/cat2/item 网址 超过 http://www.example.com/app/servlet?c
我知道以前有人问过这类问题。我有我的问题的解决方案,我想知道我是否在任何地方破坏了 REST 或 HTTP 主体。 在我的系统中,我有一个名为 member 的资源。支持通常的GET/POST/PUT
我有一个API,可以执行一些批量处理任务。假设它确实为某些资源命名。 我批量传递了7个请求,其中5个更新成功,2个失败。 我的问题是如何应对。使用HTTP时,我无法同时返回成功和错误。 有一个部分成功
我来自 RPC 世界,但目前正在调查使用 REST 是否适合我的项目。至于据我了解 Wikipedia RESTful 服务的基本思想是提供对集合及其各个元素的访问。 在我的情况下,服务器将是一个测量
我想将REST添加到我的挂毯项目中,因此需要知道如何实现它。 有什么更好的方法? 谢谢。 [编辑,从答案中复制:]我必须将GET,PUT,POST和DELETE服务添加到我的挂毯应用程序中。我看到Ta
让 /users/{id}成为 RESTful 服务中的资源 url。 启用基本身份验证,只有经过身份验证的用户才能访问该 url。 示例场景: User_1 & User_2是经过身份验证的用户,用
我是一名优秀的程序员,十分优秀!