티스토리 뷰
Open API Specfication 3?
OAS는 RESTful API에 대한 정보들을 정의하여 소스 코드에 접근하지 않아도 서비스의 기능을 검색, 확인하고 사용할 수 있게끔 지원해주는 표준 인터페이스이다.
OAS 3는 2017년 7월에 발표된 spec이며, 많은 개선이 이루어졌다고 한다. 해당 spec은 JSON, YAML을 통하여 작성할 수 있다. documentation generation tools를 사용하여서 해당 API의 기능, 테스트 코드 등을 사용자(클라이언트 개발자) 입장에서 쉽게 알 수 있게 해 준다.
스프링에서 사용할 수 있는 OAS 라이브러리
- Spring fox : OAS 2를 지원하는 라이브러리이다.
- Springdoc-openapi v1.5.1 : OAS 3을 지원하는 라이브러리이다.
https://github.com/springdoc/springdoc-openapi
Format
-
키 값에 대해 대소문자를 구분하며 특별한 경우에는 구분하지 않는다고 명시해야 한다.
-
spec의 schema는 고정된 필드 이름(식별자와)과 문자열, 패턴 값을 가진다.
#식별자 / 문자열 or 패턴 값 "field": [ 1, 2, 3 ]
-
(Json) 사용되는 Tag는 JSON Schema ruleset에 정의된 것들만 사용해야 한다.
-
YAML에서 사용되는 키 값은 YAML Failsafe schema ruleset를 무조건 따라야 한다.
-
API는 YAML 또는 JSON 형식으로 문서에 정의될 수 있지만, API 요청 및 응답 본문과 콘텐츠가 JSON 또는 YAML 일 필요는 없다.
Data Type
OAS의 타입은 JSON Schema Specification Wright Draft 00의 정의된 유형을 기반으로 한다.
- Integer → int 32
- → int 64
- number → float
- → double
- string
- → byte
- → binary
- → date
- → date-time
- → password
- boolean
Rich Text Formatting
OAS는 description필드 전체에서 CommonMark라는 기본적인 마크 다운 형식을 지원한다.
- 어떠한 텍스트 서식들을 렌더링 하는 경우에는 최소한의 마크다운 구문을 지원해야 한다.
Relative References in URLs
URL의 기본적인 속성은 모두 RFC3986에 정의된 상대 참조를 사용한다.
-
Server Object 형식을 사용하거나 Reference Object 형식을 사용한다.
# Server Object # url, desciption, variables # Server에 대한 값을 나타내는 Object이다. (client에 제공되는) { "url": "https://development.gigantic-server.com/v1", "description": "Development server" } # 복수의 Server를 나타내는 경우 { "servers": [ { "url": "https://development.gigantic-server.com/v1", "description": "Development server" }, { "url": "https://staging.gigantic-server.com/v1", "description": "Staging server" }, { "url": "https://api.gigantic-server.com/v1", "description": "Production server" } ] } # port의 대한 값이나, default 설정, BasePath 등의 정보도 제공 가능하다. "port": { "enum": [ "8443", "443" ], "default": "8443" }, "basePath": { "default": "v2" } # Reference Object # $ref # spec의 다른 component를 내부, 외부에서 참조하게끔 도와주는 Object 이다. { "$ref": "#/components/schemas/Pet" }
Example Object
요청, 응답, 매개 변수에 대한 예시를 보여준다.
# 요청 본문
requestBody:
content:
'application/json':
schema:
$ref: '#/components/schemas/Address'
examples:
foo:
summary: A foo example
value: {"foo": "bar"}
bar:
summary: A bar example
value: {"bar": "baz"}
'application/xml':
examples:
xmlExample:
summary: This is an example in XML
externalValue: 'http://example.org/examples/address-example.xml'
'text/plain':
examples:
textExample:
summary: This is a text example
externalValue: 'http://foo.bar/examples/address-example.txt'
# 응답 본문
responses:
'200':
description: your car appointment has been booked
content:
application/json:
schema:
$ref: '#/components/schemas/SuccessResponse'
examples:
confirmation-success:
$ref: '#/components/examples/confirmation-success'
# 매개 변수
parameters:
- name: 'zipCode'
in: 'query'
schema:
type: 'string'
format: 'zip-code'
examples:
zip-example:
$ref: '#/components/examples/zip-example'
Another Obejcts
- 그 외에도 수많은 객체들이 존재한다.
- Server Variable Object - 서버의 변수 정보를 나타낸다.
- License Object - Lincense 정보를 나타낸다.
- Component Object - OAS에서 제공하는 재사용 가능한 객체들의 집합이다.
- Contact Object - API와 관련된 연락처 정보를 나타낸다
- Info Object - API에 대한 메타 데이터를 제공한다
- Path Item Object
- Operation Object
- External Documentation Object
- Parameter Object
- Request Body Object
- Media Type Object
- Encoding Object
- Responses Object
- Response Object
- Callback Object
springdoc-openapi. 사용법
Gradle 의존성
implementation("org.springdoc:springdoc-openapi-ui:1.4.6")
Java Configuration 추가하기
@Configuration
public class OpenApiConfig {
@Bean
public OpenAPI customOpenAPI() {
return new OpenAPI()
.components(new Components())
.info(new Info().title("XXX Application API").description(
"XXX Application Descrptions.."));
}
}
Sample Controller
@RestController
@RequestMapplng(path = "/posts")
@Tag(name = "Domain API Names", description = "API Description")
public class HelloController {
@Operation(summary = "Find User by id", description = "ID serach by ID = {id} format"
,tags = {"Domain API Names"})
@ApiResponse(responseCode = "200", desription = "Status Code Description",
, content = (array = @ArraySchema(schema = @Schema(implementation = Post.class)))
@GetMapping(value = "/{postId}", produces = { "application/json", "application/xml" })
public ResponseEntity<List<Contact>> findById(
@Parameter(description="Id of the Post for search.") @Pathvariable Long postId){
Post postsById = PostService.findById(postId);
return ResponseEntity.status(HttpStatus.OK).body(postsById);
}
}
Open API Annotation
@Tag ( spring fox = @Api )
- name : 컨트롤러의 도메인 이름 (PostController의 경우 Post)
- description : Name에 대한 설명
@Operation ( spring fox = @ApiOperation)
- summary : 해당 메서드의 동작 정보 요약
- description : 해당 동작의 설명
- tags : 상단에 정의된 Tag의 name과 동일하게 주는 값
@ApiResponse
- responseCode : 성공시 전달할 HTTP Status Code
- desription : 해당 Code 에 대한 설명
- content : 응답되는 컨텐츠 유형 설정
- array : 단일이 아닌 복수의 자원 응답이 있을 경우 사용
@ArraySchema
- schema : 복수 자원 응답시 내부에 저장되는 리소스 설정
@Schema ( spring fox = @ApiModel, @ApiModelProperty)
- implementation : 반환되는 DTO, Entity 를 .class 형식으로 연동 (구조 상속)
@Parameter ( spring fox = @ApiIgnore, @ApiImplicitParam, @ApiParam)
- description : 해당 URL에 대한 Pathvariable, Query Parameter 설명
참고, 코드 출처
'Programming' 카테고리의 다른 글
Logging, slf4j, Logback, System.out.println() (0) | 2021.01.07 |
---|---|
Java Database Connectivity 알아보기! (0) | 2021.01.01 |
Java에서 구현할 수 있는 Proxy들 (Pure, JDK, CGLIB) (0) | 2020.12.27 |
RestTemplate, Traverson, WebClient 정리하기 (0) | 2020.12.25 |
H2의 Local(In-Memory) 와 Server(TCP) 모드 (0) | 2020.12.11 |
- Total
- Today
- Yesterday
- Cache Design
- Global Cache
- Url
- spring
- java
- RPC
- HTTP
- lambda
- URN
- URI
- RESTful
- Distributed Cache
- JVM
- hypermedia
- spring AOP
- 게으른개발자컨퍼런스
- mybatis
- JDK Dynamic Proxy
- AMQP
- rabbitmq
- 게으른 개발자 컨퍼런스
- Switch
- THP
- 소비자 관점의 api 설계 패턴과 사례 훑어보기
- Local Cache
- 근황
- JPA
- Data Locality
- cglib
- configuration
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |