使用Spring Boot + MySQL实现简单的Web REST API服务器
提纲
使用Spring Boot从零开始实现REST API服务器。
YutaKase6/spring-api-sample
目标
入口
data:image/s3,"s3://crabby-images/0b5c7/0b5c71a2b519cb3b0c93471bf671c3fd93f3bdcf" alt="undefined"
桌子
物理名論理名idユーザIDvalueユーザ情報
步骤…
首先创建项目。
data:image/s3,"s3://crabby-images/081b0/081b059352027b9747f418b22931fe4840ec1dc4" alt="ij.jpeg"
关于Gradle的确认
data:image/s3,"s3://crabby-images/560eb/560ebb0a614fe76381f86faaa0cd98c63724ed4e" alt="undefined"
在实施之前,需要考虑架构和类设计。
data:image/s3,"s3://crabby-images/e9933/e99331655a0c8d171a076622ebcbc2c051b0b948" alt="undefined"
逐步实施
在Qiita上进行Spring Boot和JPA实现REST API(领域层)的编写。
在Qiita上进行Spring Boot和JPA实现REST API(基础层)的编写。
在Qiita上进行Spring Boot和JPA实现REST API(应用层)的编写。
MySQL配置
MySQL准备中
安装并启动
% brew install mysql
% mysql.server start
创建表格
CREATE TABLE test_users (
id VARCHAR(18) PRIMARY KEY
, value TEXT DEFAULT NULL
, created_at TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP
, updated_at TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
) ENGINE=InnoDB DEFAULT CHARSET=utf8
;
mysql> desc test_users;
+------------+-------------+------+-----+-------------------+-----------------------------+
| Field | Type | Null | Key | Default | Extra |
+------------+-------------+------+-----+-------------------+-----------------------------+
| id | varchar(18) | NO | PRI | NULL | |
| value | text | YES | | NULL | |
| created_at | timestamp | NO | | CURRENT_TIMESTAMP | |
| updated_at | timestamp | NO | | CURRENT_TIMESTAMP | on update CURRENT_TIMESTAMP |
+------------+-------------+------+-----+-------------------+-----------------------------+
4 rows in set (0.00 sec)
Spring Boot配置
data:image/s3,"s3://crabby-images/c6fa6/c6fa699e8e76f705a5637ce125c78737a148513c" alt="undefined"
编写与MySQL的连接设置。
spring:
datasource:
url: jdbc:mysql://localhost:3306/<SchemaName>
username: root
password:
jpa:
hibernate:
ddl-auto: none
确认行动
执行
data:image/s3,"s3://crabby-images/e9492/e9492d6a44e1eea39e05980fd689d430625c2e92" alt="undefined"
data:image/s3,"s3://crabby-images/c4cc9/c4cc941a3e1eb196f4cdf5d698733fd12acbf455" alt="undefined"
使用Gradle执行
% ./gradlew bootRun
使用Java来执行
% ./gradlew build
% java -jar build/libs/spring-api-0.0.1-SNAPSHOT.jar
正常确认
- 登録
% curl -X POST "http://localhost:8080/v1/users" -H "Content-Type: application/json" -d "{ \"id\": \"id\", \"value\": \"value\"}" -s -w '\nstatus code: %{http_code}\n'
{"id":"id","value":"value"}
status code: 201
- 参照
% curl "http://localhost:8080/v1/users/id" -s -w '\nstatus code: %{http_code}\n'
{"id":"id","value":"value"}
status code: 200
- 削除
% curl -X DELETE "http://localhost:8080/v1/users/id" -s -w '\nstatus code: %{http_code}\n'
status code: 204
异常确认(Spring Boot 默认)
- 存在しないユーザ
% curl "http://localhost:8080/v1/users/hoge" -s -w '\nstatus code: %{http_code}\n'
{"timestamp":"2018-07-20T12:11:51.131+0000","status":500,"error":"Internal Server Error","message":"No message available","path":"/v1/users/hoge"}
status code: 500
- 定義していないメソッド
% curl "http://localhost:8080/v1/users" -s -w '\nstatus code: %{http_code}\n'
{"timestamp":"2018-07-20T12:14:08.013+0000","status":405,"error":"Method Not Allowed","message":"Request method 'GET' not supported","path":"/v1/users"}
status code: 405
- 定義していないパス
% curl "http://localhost:8080/v1/user" -s -w '\nstatus code: %{http_code}\n'
{"timestamp":"2018-07-20T12:14:14.668+0000","status":404,"error":"Not Found","message":"No message available","path":"/v1/user"}
status code: 404
还有许多其他的选择。
自定义异常情况下的响应
自定义用Spring Boot创建的REST API的错误响应 – Qiita
引入Swagger
创建单元测试
data:image/s3,"s3://crabby-images/9c846/9c846bd4553c1ab20ab96c17aff08e5dc370f42c" alt="undefined"
data:image/s3,"s3://crabby-images/e4e51/e4e51b079b7536546e83791be7731d0b2bf34b51" alt="undefined"
创建功能测试
data:image/s3,"s3://crabby-images/06a25/06a2500106b26723ed80af95a4f69c6a48cbe05b" alt="undefined"
引入记录器
data:image/s3,"s3://crabby-images/1eacd/1eacd34d19e35d8ed8a104ee140c618110fa3d54" alt=""
测量覆盖率
待定…