KotlinでGraphQL APIを呼び出す方法を解説!初心者にもわかるAPI連携の基本
生徒
「KotlinでGraphQLって使えますか?REST APIしか使ったことなくて、ちょっと難しそうです…」
先生
「もちろんKotlinでもGraphQL APIを使えるよ!GraphQLは必要なデータだけをリクエストできる新しいスタイルのAPIなんだ。基本からやってみようか。」
生徒
「お願いします!JSONとかPOSTとか出てくると混乱しちゃいます…」
先生
「ゆっくり丁寧に解説するから安心して。GraphQLの基本からKotlinでの実装方法まで、一緒にやってみよう!」
1. GraphQL APIとは?
GraphQL(グラフキューエル)とは、Facebookが開発したAPIの設計方式で、必要なデータだけを指定して取得できる特徴があります。
たとえば「ユーザーの名前と年齢だけが欲しい」ときに、それだけを明確にリクエストできます。これは「REST API」と違って、柔軟性の高い通信が可能になります。
2. GraphQLのリクエスト構造
GraphQLでは、POSTリクエストを使って「クエリ(query)」を送信します。内容はJSON形式で、次のようになります:
{
"query": "{ user { name age } }"
}
このように、取得したいフィールド(name、age)を明示的に指定します。
3. KotlinでGraphQL APIを使う準備
GraphQL APIを呼び出すには、HTTPリクエストが送れるライブラリが必要です。今回はシンプルにOkHttpを使います。
まずはGradleに以下を追加しましょう:
dependencies {
implementation("com.squareup.okhttp3:okhttp:4.12.0")
}
4. KotlinでGraphQL APIを呼び出す基本コード
次に、KotlinでGraphQL APIにPOSTリクエストを送信して、レスポンスを取得する基本コードを紹介します。
import okhttp3.MediaType.Companion.toMediaType
import okhttp3.OkHttpClient
import okhttp3.Request
import okhttp3.RequestBody.Companion.toRequestBody
fun main() {
val client = OkHttpClient()
val query = """
{
"query": "{ user { name age } }"
}
""".trimIndent()
val mediaType = "application/json; charset=utf-8".toMediaType()
val requestBody = query.toRequestBody(mediaType)
val request = Request.Builder()
.url("https://example.com/graphql")
.post(requestBody)
.build()
client.newCall(request).execute().use { response ->
println(response.body?.string())
}
}
このコードでは、JSONの文字列をリクエストボディとしてPOST送信し、サーバーからのレスポンスを受け取っています。
5. 実行結果の例
正しく通信できた場合、次のような結果が返ってきます(内容はダミーです):
{
"data": {
"user": {
"name": "Taro",
"age": 25
}
}
}
6. POSTメソッドとJSONについて
GraphQL APIを使うには、POSTメソッドという形式でリクエストを送ります。これは「サーバーにデータを渡して返事をもらう」方法です。
リクエストの中身はJSON形式で記述します。JSON(ジェイソン)は、データを「鍵と値」のペアで表現するテキスト形式で、人にもコンピュータにも読みやすいのが特徴です。
7. よくある失敗とその対処法
GraphQL APIを呼び出すときにありがちなミスには、次のようなものがあります:
- URLが間違っている(404エラー)
- クエリの文法ミス(GraphQL構文エラー)
- JSONの形式が崩れている(パースエラー)
そういったときは、println(response.body?.string())で中身を確認し、何が原因かを読み取るようにしましょう。
8. KotlinでGraphQLを使うメリットとは?
KotlinでGraphQLを使うと、必要なデータだけを取得できるため、無駄な通信が減り、効率的なネットワーク処理が可能になります。
特にモバイルアプリでは通信量を減らすことがとても大切なので、GraphQLはおすすめの選択肢です。
Kotlinを基礎からしっかり学びたい人や、 Java経験を活かしてモダンな言語にステップアップしたい人には、 定番の入門書がこちらです。
基礎からわかるKotlinをAmazonで見る※ Amazon広告リンク
9. 複雑なクエリもKotlinから送信できる?
もちろんできます。GraphQLでは「ネストされたデータ(入れ子構造)」や「引数付きのクエリ」なども使えます。
たとえば次のように、ユーザーIDを指定して情報を取得することも可能です:
{
"query": "{ user(id: 1) { name email } }"
}
Kotlinではこの文字列をリクエストボディにそのまま送るだけなので、使い方もシンプルです。
【未経験OK】Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験する60分
「プログラミングを始めたい」を形にする。最新言語Kotlinで楽しむ、ものづくりの第一歩。
本講座は、プログラミング経験が全くない方のためのエントリー講座です。「コードを書くってどういうこと?」という基本から、世界中で使われている最新言語Kotlin(コトリン)を使って、実際にプログラムを動かすまでを体験します。難しい理屈よりも、まずは「自分の手で動かす楽しさ」を最短距離で実感していただきます。
具体的な体験内容と環境
【つくるもの】
簡単な言葉を入力すると自動で返答してくれる「対話型ミニプログラム」や、計算を自動化する「便利ツール」をゼロから作成します。黒い画面に自分の書いた文字が表示される瞬間は、最高の感動体験です。
【開発環境】
プロのエンジニアが実際に使っている開発ツールIntelliJ IDEA(インテリジェイ)をインストールします。ボタン一つで日本語化し、初心者でも迷わず操作できる「魔法の設定」を一緒に行います。
この60分で得られる3つの体験
プロと同じ道具を揃えることで、明日から一人でもプログラミングを続けられる環境が整います。
「変数」や「型」といった難しい言葉も、身近な例え話で解説。モヤモヤをゼロにします。
Kotlinは英語に近くて読みやすいのが特徴。自分でコードを読んで、間違いを見つけるコツも伝授します。
※本講座は、パソコン操作が不安な方でも安心して受講いただける完全マンツーマンです。あなたのペースに合わせて、一つずつ丁寧に進めていきます。
Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験