質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

API

APIはApplication Programming Interfaceの略です。APIはプログラムにリクエストされるサービスがどのように動作するかを、デベロッパーが定めたものです。

Q&A

解決済

1回答

2242閲覧

readAsBinaryString() の逆の動作が分かりません

xmg

総合スコア20

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

API

APIはApplication Programming Interfaceの略です。APIはプログラムにリクエストされるサービスがどのように動作するかを、デベロッパーが定めたものです。

0グッド

0クリップ

投稿2020/09/11 08:15

編集2020/09/11 08:18

問題点

バイナリ コードを text editor または ブラウザ API から出力させる方法が分からない

設定
バイナリ コードを読み込んで、javascript 上で
HEX 変換して編集をした内容を
再び 2進数に変換して保存しようと努力をしています。

どのようにすれば、バイナリ ファイルとして出力することができるでしょうか。

javascript

1 2 var blob = new Blob([dataToSave], {type: "application/octet-binary"}); 3

ファイル タイプ を上記のように指定しても
出力されたファイルは、text editor で開くと
編集前のバイナリ コードと同じような
文字化け表示がなされずに
2進数の 0101 のtext 表示のままでした。

よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

readAsBinaryString()

readAsArrayBuffer() を使ってください。

バイナリデータを JavaScript の {string} で無理やり扱っていたのは
TypedArray 登場以前の古い JavaScript になります(開発者が文字化けを許容していた)。

MDN readAsBinaryString より

File APIの仕様から一度削除されましたが、後方互換のために再導入されました。
FileReader.readAsArrayBuffer() の使用が推奨されています。

Wikipedia コンピュータの数値表現(追記

再び 2進数

2進数の単位はbitになりますので、 テキスト化された "0","1" の値はそれぞれ、16進数(単位はbyte)の 0x30,0x31 になるはずです。

逆の動作

HEX化したテキストの場合、byte単位(16進数)で考えます。

javascript

1// utf-8 1byte文字(可視文字)の範囲でHEX化してみる例(追記 2// [..."Hello,world!"].map( s=>s.charCodeAt(0).toString(16) ).join(""); 3// => "48656c6c6f2c776f726c6421" 4var hexstring = "48656c6c6f2c776f726c6421"; 5 6var bytes = hexstring.match(/[\da-f]{2}/ig) 7 .map( c => Number("0x"+c) ); // => バイト配列 / Uint8Array() に渡せる 8 9/* 10// 参考 binary-string : 1byte ごとに String.fromCharCode() で文字列化する 11var binstr = bytes 12 .map( n => String.fromCharCode(n) ) 13 .join(""); // => "Hello,world!" 現在は utf-8 テキストデータに限って利用 14*/ 15 16var dataToSave = new Uint8Array( bytes );

データ形式が定まっていないバイナリの mimeType は application/octet-stream です。

  • Blobの派生オブジェクトFile もあります

上記コードの続きで

javascript

1//var blob = new Blob([dataToSave], {type: "application/octet-binary"}); 2var file = new File([dataToSave], "filename", {type: "application/octet-stream"});

過去のご質問にも回答していますが、convertArrayBufferToHexArray() は、ArrayBufferから、通常の配列に変換(各バイトの値は HEXで示す2文字にする)しています。

javascript

1// buf はfileから読んだ ArrayBuffer 2var hexstring = convertArrayBufferToHexArray( buf ).join("");

投稿2020/09/11 09:33

編集2020/09/16 05:36
AkitoshiManabe

総合スコア5434

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

xmg

2020/09/12 00:57

ごていねいな回答をいただいて、非常に感謝しております。 早速、上記のコードを使用させていただきました。 結果は、 binary 化された文字列を text editor で表示すると、空白のページが出るだけでした。 上のコード見本の中で、 ..... var dataToSave = new Uint8Array( bytes ); ..... の引用変数:bytes を binstr に訂正しても、バイナリコードが出力できませんでした。 お手数ですが、上のコード見本の hexstring の値を、BINファイルとして File API を用いてダウンロードする HTML構文と javascript の一体化された手本をご教示いただけますでしょうか。 よろしくお願いいたします。
AkitoshiManabe

2020/09/12 02:34 編集

MDN にあるとおり、 new Uint8Array(bytes) は File のコンストラクタに渡すために作成したArrayBufferViewerに過ぎません。 > 一体化された手本をご教示いただけますでしょうか いえ、それでは上達できません。詳細な処理の連続を理解してください。(邪魔なコードはコメントしました)
xmg

2020/09/16 01:23

AkitoshiManabe様へ 懇切ていねいなご指導をいただき、感謝しております。 上記のお答えの内容を理解できるように、map関数のことなどをこの週末から本日まで学習してまいりました。 現時点で、HEXコードを2進数の文字列に変換するだけではなく、buffer に渡せるような配列に変えなければならないということだと理解しています。 そのために、新たな配列に変換されたコードを格納する必要があることは分かりますが、for loop で buffer 内の各バイトをひとつひとつ変換する代わりに map を用いるにあたって、上記の回答に示されている変数 C の定義がどうなっているのかが分からずに壁に当たってしまいました。 map 関数の見本をいくつも調べましたが、参照する大元のHEXデータを 以下の式で、どうやって変換しているのか 変数 c の意味するところが分かりません。 var bytes = hexstring.match(/[\da-f]{2}/ig) .map( c => Number("0x"+c) ); ------------------------------- いまだに HEXコードの文字列を2進数に変換して、それを text file ではなく、多くのアプリケーションがデーター保存に使用している binary file に変換するやり方が分かりません。 初歩的なことで申し訳ありませんが、WEB上をいくら探し回っても、BINARY保存の方法が C 言語のような関数で javascript に存在していない模様ですので、基本的なバイナリ保存法についてご指導をお願いいたします。
AkitoshiManabe

2020/09/16 01:52 編集

> HEXコードを2進数の文字列に変換 バイナリデータ(ファイルや、通信における生データ)は16進数です。 > map 関数の見本をいくつも調べましたが ... String#match() の引数に "g"フラグ(global)のついた正規表現を与えると、Arrayが返却されます。 console.log( hexstring.match(/[\da-f]{2}/ig) ) 配列要素は "00" ~ "FF" の16進数を示す文字列なので、プレフィックス"0x"を結合して数値化した結果を返却しています(map() で使っている仮引数 c は1バイト分の charCode と思ってください)。 メソッドチェーンは .methodName() ごとに分解して考えたほうが理解しやすいと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問