Proces aplikacji
Aby skorzystać z API, należy najpierw przejść do strony Kling Videos Generation API i złożyć wniosek o odpowiednią usługę. Po wejściu na stronę, kliknij przycisk „Acquire”, jak pokazano na obrazku:
Jeśli nie jesteś zalogowany lub zarejestrowany, automatycznie zostaniesz przekierowany na stronę logowania, aby zarejestrować się i zalogować. Po zalogowaniu lub rejestracji automatycznie wrócisz na bieżącą stronę.
Podczas pierwszej aplikacji otrzymasz darmowy limit, który pozwala na bezpłatne korzystanie z tego API.
Podstawowe użycie
Najpierw zapoznaj się z podstawowym sposobem użycia, czyli wprowadzeniem słowa kluczowegoprompt, działania action, linku do obrazu referencyjnego start_image_url oraz modelu model, aby uzyskać przetworzony wynik. Najpierw musisz przekazać pole action, którego wartość to text2video. Obejmuje ono trzy główne działania: generowanie wideo z tekstu (text2video), generowanie wideo z obrazu (image2video), rozszerzenie wideo (extend). Następnie musimy wprowadzić model model, który obecnie obejmuje głównie modele kling-v1, kling-v1-6, kling-v2-master, kling-v2-1-master, kling-v2-5-turbo, kling-video-o1, szczegóły są następujące:

accept: format odpowiedzi, który chcemy otrzymać, tutaj wpisujemyapplication/json, czyli format JSON.authorization: klucz do wywołania API, który można wybrać z rozwijanej listy po złożeniu wniosku.
model: model generujący wideo, główniekling-v1,kling-v1-6,kling-v2-master,kling-v2-1-master,kling-v2-5-turbo,kling-video-o1.mode: tryb generowania wideo, głównie standardowy trybstdi tryb superszybkipro.action: działanie związane z generowaniem wideo, które obejmuje trzy główne działania: generowanie wideo z tekstu (text2video), generowanie wideo z obrazu (image2video), rozszerzenie wideo (extend).start_image_url: link do obrazu referencyjnego, który musi być przesłany, gdy wybierzesz działanie generowania wideo z obrazuimage2video.end_image_url: opcjonalne, określa końcową klatkę w przypadku generowania wideo z obrazu.aspect_ratio: proporcje wideo, opcjonalne, wspiera16:9,9:16,1:1, domyślnie16:9.cfg_scale: intensywność związku, zakres [0,1], im większa wartość, tym bardziej zgodna z podanym słowem kluczowym.camera_control: opcjonalne, parametry kontrolujące ruch kamery, wspiera predefiniowane typy/simple oraz konfiguracje horizontal, vertical, pan, tilt, roll, zoom.negative_prompt: opcjonalne, słowa kluczowe, które nie powinny się pojawić, maksymalnie 200 znaków.element_list: lista referencyjna dla głównych elementów, stosowana tylko w modelukling-video-o1, szczegóły dotyczące użycia tego parametru można znaleźć w dokumentacji.video_list: referencyjne wideo, uzyskiwane przez URL, stosowane tylko w modelukling-video-o1, szczegóły dotyczące użycia tego parametru można znaleźć w dokumentacji.prompt: słowo kluczowe.callback_url: URL, na który mają być zwracane wyniki.

success, status zadania generowania wideo.task_id, ID zadania generowania wideo.video_id, ID wideo wygenerowanego w ramach zadania.video_url, link do wygenerowanego wideo.duration, długość wygenerowanego wideo.state, status zadania generowania wideo.
data uzyskamy wygenerowane wideo Kling.
Dodatkowo, jeśli chcesz wygenerować odpowiedni kod integracyjny, możesz go bezpośrednio skopiować, na przykład kod CURL wygląda następująco:
Funkcja rozszerzenia wideo
Jeśli chcesz kontynuować generowanie już wygenerowanego wideo Kling, możesz ustawić parametraction na extend i wprowadzić ID wideo, które chcesz kontynuować. ID wideo można uzyskać na podstawie podstawowego użycia, jak pokazano na poniższym obrazku:

Uwaga, tutaj video_id w wideo to ID wygenerowanego wideo. Jeśli nie wiesz, jak wygenerować wideo, możesz odwołać się do podstawowego użycia opisanego powyżej.
Następnie musimy wprowadzić kolejne słowo kluczowe, które chcemy rozszerzyć, aby dostosować generowanie wideo, co pozwoli na określenie następujących treści:
model:Model generujący wideo, głównie modelekling-v1,kling-v1-5ikling-v1-6.mode:Tryb generowania wideo, głównie standardowy trybstdi tryb superszybkipro.duration:Czas trwania wideo w tej zadaniu generowania wideo, głównie 5s i 10s.start_image_url:Gdy wybierzesz zachowanie generowania wideo z obrazuimage2video, musisz przesłać link do referencyjnego obrazu pierwszej klatki.prompt:Słowo kluczowe.


Asynchroniczny callback
Ponieważ czas generowania przez API Kling Videos jest stosunkowo długi, wynosi około 1-2 minut, jeśli API nie odpowiada przez dłuższy czas, żądanie HTTP będzie utrzymywać połączenie, co prowadzi do dodatkowego zużycia zasobów systemowych, dlatego to API oferuje również wsparcie dla asynchronicznych callbacków. Cały proces polega na tym, że klient inicjuje żądanie, dodatkowo określając polecallback_url, po wysłaniu żądania API natychmiast zwraca wynik, zawierający pole task_id, które reprezentuje aktualne ID zadania. Po zakończeniu zadania, wynik generowania wideo zostanie wysłany do określonego przez klienta callback_url w formie POST JSON, w tym również zawierając pole task_id, dzięki czemu wyniki zadania można powiązać za pomocą ID.
Poniżej przyjrzymy się, jak to dokładnie działa na przykładzie.
Najpierw, callback Webhook to usługa, która może odbierać żądania HTTP, deweloperzy powinni zastąpić to URL swojego serwera HTTP. Dla wygody demonstracji użyjemy publicznej strony przykładowej Webhook https://webhook.site/, otwierając tę stronę można uzyskać URL Webhook, jak pokazano na obrazku:
Skopiuj ten URL, aby użyć go jako Webhook, przykładowy URL to https://webhook.site/624b2c78-6dbd-4618-9d2b-b32eade6d8c3.
Następnie możemy ustawić pole callback_url na powyższy URL Webhook, jednocześnie wypełniając odpowiednie parametry, szczegóły jak na obrazku:

https://webhook.site/624b2c78-6dbd-4618-9d2b-b32eade6d8c3 zaobserwować wynik generowania wideo, jak pokazano na obrazku:
Treść jest następująca:
task_id, a pozostałe pola są podobne do powyższych, dzięki czemu można powiązać zadanie za pomocą tego pola.
Obsługa błędów
Podczas wywoływania API, jeśli wystąpią błędy, API zwróci odpowiedni kod błędu i informacje. Na przykład:400 token_mismatched:Złe żądanie, prawdopodobnie z powodu brakujących lub nieprawidłowych parametrów.400 api_not_implemented:Złe żądanie, prawdopodobnie z powodu brakujących lub nieprawidłowych parametrów.401 invalid_token:Nieautoryzowany, nieprawidłowy lub brakujący token autoryzacyjny.429 too_many_requests:Zbyt wiele żądań, przekroczono limit szybkości.500 api_error:Błąd wewnętrzny serwera, coś poszło nie tak na serwerze.

