LoginSignup
0
0

More than 1 year has passed since last update.

FileオブジェクトをBASE64エンコードする方法

Last updated at Posted at 2022-08-27

クライアントサイドのお話です。

フォームで取得したファイルオブジェクトをREST APIにJSON形式で送りつけたいことってありますよね。
そのままじゃ送れないのでBASE64エンコードをする必要があると思います。
意外と簡単に行かなく、めちゃくちゃ処理が重くなってはまったりしたのでここに動くソースを残します。
クライアントサイドで重い処理を動かして兵庫県警に逮捕されないように気を付けましょう。

const uint8Array = Array.from<number>(new Uint8Array(await file.arrayBuffer()))

let encodedStr = ''

for (let i = 0; i < uint8Array.length; i += 1024) {
    encodedStr += String.fromCharCode.apply(
        null, uint8Array.slice(i, i + 1024)
    )
}

const base64 = window.btoa(encodedStr)
0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0