KotlinのAPI通信でGETリクエストを送る方法!初心者向け徹底ガイド
生徒
「Kotlinでインターネット上のデータを取得したいんですけど、どうやってAPIにアクセスすればいいんですか?」
先生
「KotlinでAPI通信を行うには、まず『GETリクエスト』を使ってサーバーにデータを取りに行くのが基本です。URLを指定してリクエストを送ることで、情報を受け取ることができますよ。」
生徒
「GETリクエストってどうやって書くんですか?ライブラリとか必要なんですか?」
先生
「今回は初心者でも扱いやすいライブラリ『OkHttp(オーケーエイチティーティーピー)』を使って、GETリクエストの方法を丁寧に解説していきます!」
1. KotlinでGETリクエストとは?
GETリクエストとは、URLを指定して外部のサーバーにデータを取りにいく通信方法のひとつです。Kotlinではこのリクエストを使って、天気予報やニュース、商品情報などのデータを取得することができます。
たとえば、ニュースアプリや天気アプリでは、APIを使ってインターネット上から情報を取得しています。このときに活躍するのがGETリクエストです。
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リクエストを送る基本コード
それでは実際に、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リクエストの流れを図解で理解しよう
初心者にとっては、GETリクエストの流れがイメージしづらいかもしれません。そこで、簡単な流れをまとめてみましょう。
- ① OkHttpClient を作成 → 通信の土台
- ② Request を作成 → どこにアクセスするか設定
- ③ execute() で通信を実行 → 結果を取得
- ④ response.body?.string() → データを文字列として取得
このように、4つのステップでKotlinから簡単にインターネット通信ができるのです。
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を変えるだけで色々なデータが取れる
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データを見やすく扱うには?
GETリクエストで取得したデータはほとんどがJSON(ジェイソン)形式です。このままだと文字列として扱うだけなので見づらく、活用しにくいです。
そのため、前回の記事で紹介したようなGsonやMoshiなどを使ってJSONをパースし、Kotlinのデータクラスに変換すると非常に便利です。
【未経験OK】Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験する60分
「プログラミングを始めたい」を形にする。最新言語Kotlinで楽しむ、ものづくりの第一歩。
本講座は、プログラミング経験が全くない方のためのエントリー講座です。「コードを書くってどういうこと?」という基本から、世界中で使われている最新言語Kotlin(コトリン)を使って、実際にプログラムを動かすまでを体験します。難しい理屈よりも、まずは「自分の手で動かす楽しさ」を最短距離で実感していただきます。
具体的な体験内容と環境
【つくるもの】
簡単な言葉を入力すると自動で返答してくれる「対話型ミニプログラム」や、計算を自動化する「便利ツール」をゼロから作成します。黒い画面に自分の書いた文字が表示される瞬間は、最高の感動体験です。
【開発環境】
プロのエンジニアが実際に使っている開発ツールIntelliJ IDEA(インテリジェイ)をインストールします。ボタン一つで日本語化し、初心者でも迷わず操作できる「魔法の設定」を一緒に行います。
この60分で得られる3つの体験
プロと同じ道具を揃えることで、明日から一人でもプログラミングを続けられる環境が整います。
「変数」や「型」といった難しい言葉も、身近な例え話で解説。モヤモヤをゼロにします。
Kotlinは英語に近くて読みやすいのが特徴。自分でコードを読んで、間違いを見つけるコツも伝授します。
※本講座は、パソコン操作が不安な方でも安心して受講いただける完全マンツーマンです。あなたのペースに合わせて、一つずつ丁寧に進めていきます。
Kotlinで始めるプログラミング入門|ゼロから「動く喜び」を体験