SDKs
Java
Thunderbit Open API를 위한 Java의 관용적인 패턴
java.net.http.HttpClient(내장, Java 11+) 를 사용하세요. connection pooling 과 retry 등 더 풍부한 기능이 필요하다면 OkHttp + Jackson 을 함께 사용하세요.
설정
import java.net.URI;
import java.net.http.HttpClient;
import java.net.http.HttpRequest;
import java.net.http.HttpResponse;
import java.time.Duration;
private static final String API = "https://openapi.thunderbit.com/openapi/v1";
private static final HttpClient CLIENT = HttpClient.newBuilder()
.connectTimeout(Duration.ofSeconds(10))
.build();
private static HttpRequest.Builder request(String path) {
return HttpRequest.newBuilder()
.uri(URI.create(API + path))
.header("Authorization", "Bearer " + System.getenv("THUNDERBIT_API_KEY"))
.header("Content-Type", "application/json")
.timeout(Duration.ofSeconds(60));
}페이지 Distill
String body = "{\"url\":\"https://thunderbit.com/playground\"}";
HttpResponse<String> res = CLIENT.send(
request("/distill").POST(HttpRequest.BodyPublishers.ofString(body)).build(),
HttpResponse.BodyHandlers.ofString()
);
if (res.statusCode() >= 400) throw new RuntimeException(res.body());구조화된 데이터 Extract
String body = """
{
"url": "https://example.com/product/iphone-15-pro",
"schema": {
"type": "object",
"properties": {
"name": { "type": "string" },
"price": { "type": "number" }
},
"required": ["name", "price"]
}
}
""";
HttpResponse<String> res = CLIENT.send(
request("/extract").POST(HttpRequest.BodyPublishers.ofString(body)).build(),
HttpResponse.BodyHandlers.ofString()
);응답을 Jackson 또는 Gson 으로 도메인 타입에 파싱하세요.
Batch + Webhook
String body = """
{
"urls": ["https://example.com/page1", "https://example.com/page2"],
"webhook": {
"url": "https://your-server.com/webhook",
"secret": "%s"
}
}
""".formatted(System.getenv("WEBHOOK_SECRET"));
HttpResponse<String> res = CLIENT.send(
request("/batch/distill").POST(HttpRequest.BodyPublishers.ofString(body)).build(),
HttpResponse.BodyHandlers.ofString()
);핸들러에서 Webhook 시그니처를 검증하세요 —— Webhooks 를 참고하세요.
공식 Java SDK 가 개발 중입니다 —— 곧 다시 확인해 주세요.