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

KotlinのAPI通信でファイルアップロードを実装する方法!初心者でもわかるネットワーク連携の基本

KotlinのAPI通信でファイルアップロードを実装する方法
KotlinのAPI通信でファイルアップロードを実装する方法

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

生徒

「Kotlinで写真やPDFなどのファイルをサーバーに送るには、どうすればいいんですか?」

先生

「ファイルを送るときは、API通信の中でも“ファイルアップロード”という方法を使うんだよ。KotlinとOkHttpを使えば簡単に実装できるよ。」

生徒

「画像をアップロードするアプリって多いですよね!仕組みがわかれば自分でも作れそうです。」

先生

「そうだね。今回は、ファイルアップロードの基本をKotlinで一緒に学んでいこう!」

1. API通信でファイルを送るとは?

1. API通信でファイルを送るとは?
1. API通信でファイルを送るとは?

ファイルアップロードとは、スマートフォンやパソコンの中にある画像やドキュメントなどのファイルを、インターネット経由でサーバーに送る仕組みのことです。

これにはmultipart/form-dataという形式を使って、データを複数のパーツに分けて送信します。

2. Kotlinで使うライブラリの準備

2. Kotlinで使うライブラリの準備
2. Kotlinで使うライブラリの準備

今回使うのは、OkHttpという通信ライブラリです。Kotlinと相性が良く、多くのアプリで使われています。

まずはGradleの設定ファイルに次のコードを追加しましょう:


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

3. ファイルアップロードの基本コード

3. ファイルアップロードの基本コード
3. ファイルアップロードの基本コード

では、実際にKotlinでファイルアップロードを行う基本コードを見てみましょう。今回はローカルにあるテキストファイルを例にします。


import okhttp3.*
import java.io.File

fun main() {
    val client = OkHttpClient()

    val file = File("sample.txt")
    val mediaType = "text/plain".toMediaTypeOrNull()
    val requestBody = file.asRequestBody(mediaType)

    val multipartBody = MultipartBody.Builder()
        .setType(MultipartBody.FORM)
        .addFormDataPart("file", file.name, requestBody)
        .build()

    val request = Request.Builder()
        .url("https://example.com/upload")
        .post(multipartBody)
        .build()

    client.newCall(request).execute().use { response ->
        println(response.body?.string())
    }
}

MultipartBodyを使って、ファイルをmultipart/form-data形式でリクエストに含めています。

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

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

※ Amazon広告リンク

4. 実行結果のイメージ

4. 実行結果のイメージ
4. 実行結果のイメージ

サーバー側が正しく受け取れば、次のようなJSONレスポンスが返ってくることがあります。


{
  "status": "success",
  "message": "ファイルを受け取りました"
}

5. ファイルの種類に応じたMIMEタイプとは?

5. ファイルの種類に応じたMIMEタイプとは?
5. ファイルの種類に応じたMIMEタイプとは?

アップロードするファイルの種類によって、MIMEタイプという値を設定します。これはファイルの種類を表す目印です。

  • 画像(JPEG) → image/jpeg
  • 画像(PNG) → image/png
  • PDF → application/pdf
  • テキスト → text/plain

この設定が間違っていると、サーバー側で処理できないことがあるので注意しましょう。

6. エラーハンドリングも忘れずに

6. エラーハンドリングも忘れずに
6. エラーハンドリングも忘れずに

ファイルアップロード中に、インターネットが切れたり、サーバーが応答しなかったりすることがあります。そういうときはtry-catchでエラーを安全に処理しましょう。


try {
    client.newCall(request).execute().use { response ->
        println(response.body?.string())
    }
} catch (e: Exception) {
    println("エラーが発生しました: ${e.message}")
}

7. 複数のファイルを同時にアップロードしたい場合は?

7. 複数のファイルを同時にアップロードしたい場合は?
7. 複数のファイルを同時にアップロードしたい場合は?

画像を複数選んで一気にアップロードしたいというケースもよくあります。そのときはaddFormDataPartを複数回使えばOKです。


val multipartBody = MultipartBody.Builder()
    .setType(MultipartBody.FORM)
    .addFormDataPart("file1", file1.name, file1.asRequestBody("image/jpeg".toMediaType()))
    .addFormDataPart("file2", file2.name, file2.asRequestBody("image/jpeg".toMediaType()))
    .build()

このように複数のfileをパーツとして追加することで、同時に送信できます。

8. Kotlinでファイルアップロードが使われる場面

8. Kotlinでファイルアップロードが使われる場面
8. Kotlinでファイルアップロードが使われる場面

KotlinでファイルをAPI経由でアップロードする技術は、以下のような場面で使われます:

  • プロフィール画像のアップロード
  • チャットアプリで画像やPDFを送信
  • お問い合わせフォームで書類提出

どれも実用的なシーンばかりなので、しっかり理解しておきたいですね。

関連記事:
カテゴリの一覧へ
新着記事
New1
Go言語
Go言語の短絡評価(ショートサーキット)を使った条件式の工夫をやさしく解説!初心者でも理解できる基本知識
New2
Go言語
Go言語の構造体の初期化パターンとコンストラクタ的関数の書き方を徹底解説!初心者でもわかる基本と実用例
New3
Kotlin
Kotlinの例外処理とキャンセルの連携を完全ガイド!初心者でもわかるCoroutineExceptionHandlerの使い方
New4
Go言語
Go言語のクロージャとは?関数内関数の活用例と仕組み
人気記事
No.1
Java&Spring記事人気No1
Kotlin
KotlinのChannelでデータをやり取りする方法を完全ガイド!初心者にもわかる非同期通信の基本
No.2
Java&Spring記事人気No2
Go言語
Go言語でのDB接続情報を環境変数で管理する方法|初心者でも安全に設定
No.3
Java&Spring記事人気No3
Kotlin
Android Studioのインストール手順と初期設定を初心者向けに完全解説!
No.4
Java&Spring記事人気No4
Kotlin
Kotlinのビルド設定エラーと解決法まとめ!初心者向けGradleトラブル対処ガイド
No.5
Java&Spring記事人気No5
Kotlin
Gradleファイル(build.gradle.kts)の書き方と役割をやさしく解説!Kotlin初心者向け完全ガイド
No.6
Java&Spring記事人気No6
Kotlin
Kotlinでテキスト表示・編集!初心者でもわかるTextViewとEditTextの使い方
No.7
Java&Spring記事人気No7
Go言語
Go言語のgo.modファイル完全ガイド!初心者でもわかる仕組みと書き方
No.8
Java&Spring記事人気No8
Swift
Swift Playgroundの使い方を完全解説!初心者に最適な学習環境の始め方

💻 作業効率アップに

ノートPCを縦置きしてデスクを広く。
省スペースで片づく定番スタンド

UGREEN 縦型スタンドをAmazonで見る

※ Amazon広告リンク