カテゴリ: Kotlin 更新日: 2026/01/09

KotlinのAPI通信でGETリクエストを送る方法!初心者向け徹底ガイド

KotlinのAPI通信でGETリクエストを送る方法
KotlinのAPI通信でGETリクエストを送る方法

先生と生徒の会話形式で理解しよう

生徒

「Kotlinでインターネット上のデータを取得したいんですけど、どうやってAPIにアクセスすればいいんですか?」

先生

「KotlinでAPI通信を行うには、まず『GETリクエスト』を使ってサーバーにデータを取りに行くのが基本です。URLを指定してリクエストを送ることで、情報を受け取ることができますよ。」

生徒

「GETリクエストってどうやって書くんですか?ライブラリとか必要なんですか?」

先生

「今回は初心者でも扱いやすいライブラリ『OkHttp(オーケーエイチティーティーピー)』を使って、GETリクエストの方法を丁寧に解説していきます!」

1. KotlinでGETリクエストとは?

1. KotlinでGETリクエストとは?
1. KotlinでGETリクエストとは?

GETリクエストとは、URLを指定して外部のサーバーにデータを取りにいく通信方法のひとつです。Kotlinではこのリクエストを使って、天気予報やニュース、商品情報などのデータを取得することができます。

たとえば、ニュースアプリや天気アプリでは、APIを使ってインターネット上から情報を取得しています。このときに活躍するのがGETリクエストです。

2. OkHttpとは?API通信の必須ライブラリ

2. OkHttpとは?API通信の必須ライブラリ
2. OkHttpとは?API通信の必須ライブラリ

OkHttp(オーケーエイチティーティーピー)は、KotlinやJavaでよく使われるAPI通信ライブラリです。初心者でも簡単に使えるのが特徴で、GETリクエストやPOSTリクエストなど、さまざまなHTTP通信に対応しています。

まずは、Gradleに以下のようにライブラリを追加します。


dependencies {
    implementation("com.squareup.okhttp3:okhttp:4.12.0")
}

これで、KotlinプロジェクトからOkHttpを使ってAPI通信ができるようになります。

3. KotlinでGETリクエストを送る基本コード

3. KotlinでGETリクエストを送る基本コード
3. KotlinでGETリクエストを送る基本コード

それでは実際に、KotlinでGETリクエストを送るコードを見てみましょう。まずは基本的な使い方です。


import okhttp3.OkHttpClient
import okhttp3.Request

fun main() {
    val client = OkHttpClient()

    val request = Request.Builder()
        .url("https://jsonplaceholder.typicode.com/posts/1")
        .build()

    val response = client.newCall(request).execute()
    println(response.body?.string())
}

このコードでは、OkHttpClientを使ってリクエストを作成し、実行しています。URLに指定しているのはテスト用APIです。

実行すると、以下のようなJSON形式のデータが取得できます。


{
    "userId": 1,
    "id": 1,
    "title": "sunt aut facere repellat provident occaecati",
    "body": "quia et suscipit\nsuscipit recusandae..."
}

4. GETリクエストの流れを図解で理解しよう

4. GETリクエストの流れを図解で理解しよう
4. GETリクエストの流れを図解で理解しよう

初心者にとっては、GETリクエストの流れがイメージしづらいかもしれません。そこで、簡単な流れをまとめてみましょう。

  • ① OkHttpClient を作成 → 通信の土台
  • ② Request を作成 → どこにアクセスするか設定
  • ③ execute() で通信を実行 → 結果を取得
  • ④ response.body?.string() → データを文字列として取得

このように、4つのステップでKotlinから簡単にインターネット通信ができるのです。

5. 通信結果を安全に扱うには?

5. 通信結果を安全に扱うには?
5. 通信結果を安全に扱うには?

実際の開発では、通信エラーが起きる可能性もあるため、try-catch文で例外処理を行うことが大切です。以下のように書くことで、エラー時にアプリが止まらず、安全に動作します。


try {
    val response = client.newCall(request).execute()
    if (response.isSuccessful) {
        println(response.body?.string())
    } else {
        println("エラーコード: ${response.code}")
    }
} catch (e: Exception) {
    println("通信に失敗しました: ${e.message}")
}

6. URLを変えるだけで色々なデータが取れる

6. URLを変えるだけで色々なデータが取れる
6. URLを変えるだけで色々なデータが取れる

GETリクエストは、URLを変えるだけでさまざまな情報を取得できます。たとえば、天気APIや為替レート、YouTubeの動画一覧などもGETリクエストで取得できます。

例:天気APIを使うとき


val request = Request.Builder()
    .url("https://api.weatherapi.com/v1/current.json?key=YOUR_API_KEY&q=Tokyo")
    .build()

このようにURLにパラメータ(例:q=Tokyo)をつけて送ることで、特定の地域の情報を取得できます。

Kotlinを基礎からしっかり学びたい人や、 Java経験を活かしてモダンな言語にステップアップしたい人には、 定番の入門書がこちらです。

基礎からわかるKotlinをAmazonで見る

※ Amazon広告リンク

7. JSONデータを見やすく扱うには?

7. JSONデータを見やすく扱うには?
7. JSONデータを見やすく扱うには?

GETリクエストで取得したデータはほとんどがJSON(ジェイソン)形式です。このままだと文字列として扱うだけなので見づらく、活用しにくいです。

そのため、前回の記事で紹介したようなGsonMoshiなどを使ってJSONをパースし、Kotlinのデータクラスに変換すると非常に便利です。

関連セミナーのご案内

【未経験OK】Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験する60分

「プログラミングを始めたい」を形にする。最新言語Kotlinで楽しむ、ものづくりの第一歩。

本講座は、プログラミング経験が全くない方のためのエントリー講座です。「コードを書くってどういうこと?」という基本から、世界中で使われている最新言語Kotlin(コトリン)を使って、実際にプログラムを動かすまでを体験します。難しい理屈よりも、まずは「自分の手で動かす楽しさ」を最短距離で実感していただきます。

具体的な体験内容と環境

【つくるもの】
簡単な言葉を入力すると自動で返答してくれる「対話型ミニプログラム」や、計算を自動化する「便利ツール」をゼロから作成します。黒い画面に自分の書いた文字が表示される瞬間は、最高の感動体験です。

【開発環境】
プロのエンジニアが実際に使っている開発ツールIntelliJ IDEA(インテリジェイ)をインストールします。ボタン一つで日本語化し、初心者でも迷わず操作できる「魔法の設定」を一緒に行います。

この60分で得られる3つの体験

1. 自分のパソコンが「開発基地」に

プロと同じ道具を揃えることで、明日から一人でもプログラミングを続けられる環境が整います。

2. プログラミングの「仕組み」がスッキリ

「変数」や「型」といった難しい言葉も、身近な例え話で解説。モヤモヤをゼロにします。

3. 「読みやすい」から「直せる」へ

Kotlinは英語に近くて読みやすいのが特徴。自分でコードを読んで、間違いを見つけるコツも伝授します。

※本講座は、パソコン操作が不安な方でも安心して受講いただける完全マンツーマンです。あなたのペースに合わせて、一つずつ丁寧に進めていきます。

セミナー画像

Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験

関連記事:
カテゴリの一覧へ
新着記事
New1
Go言語
Go言語のスコープとは?ローカル変数・グローバル変数の違いと使い分け
New2
Go言語
Go言語の構文ルールまとめ!インデント・セミコロンなど最初に知っておくポイント
New3
Kotlin
KotlinのwithTimeoutでタイムアウト処理を設定しよう!初心者にもわかる非同期の安全な止め方
New4
Go言語
Go言語のマップの順序保証がない理由と扱い方の工夫をやさしく解説!初心者でもわかる基本知識
人気記事
No.1
Java&Spring記事人気No1
Swift
Swift Playgroundの使い方を完全解説!初心者に最適な学習環境の始め方
No.2
Java&Spring記事人気No2
Go言語
Go言語でREST APIを作る設計と実装パターン完全ガイド!初心者でもわかるAPI開発
No.3
Java&Spring記事人気No3
Go言語
Swiftの配列(Array)の使い方を完全ガイド!初心者でもわかるデータのまとめ方
No.4
Java&Spring記事人気No4
Kotlin
Kotlinのsettings.gradleファイルを完全解説!初心者でもわかるプロジェクト設定の基本
No.5
Java&Spring記事人気No5
Kotlin
Android Studioのインストール手順と初期設定を初心者向けに完全解説!
No.6
Java&Spring記事人気No6
Go言語
Go言語のトランザクション処理を完全解説!Begin・Commit・Rollbackを初心者向けにやさしく理解
No.7
Java&Spring記事人気No7
Go言語
Swiftの変数と定数の使い方を完全ガイド!初心者でもわかる基本文法
No.8
Java&Spring記事人気No8
Go言語
Go言語のgo installコマンドの役割とインストール先の仕組みを徹底解説!