ホームページ > ウェブフロントエンド > jsチュートリアル > Javascript の「atob」が UTF-8 Base64 文字列を適切にデコードできないのはなぜですか?

Javascript の「atob」が UTF-8 Base64 文字列を適切にデコードできないのはなぜですか?

DDD
リリース: 2024-11-01 23:10:29
オリジナル
472 人が閲覧しました

Why does Javascript's `atob` fail to decode UTF-8 base64 strings properly?

JavaScript の atob を使用して Base64 をデコードすると、utf-8 文字列が適切にデコードされない

JavaScript の atob は、エンコードされた Base64 文字列を適切にデコードできますASCII 文字の場合、たとえば window.atob('YQ==') は ASCII 文字「a」を返します。ただし、UTF-8 Unicode 文字でエンコードされた Base64 文字列は適切にデコードされません。たとえば、window.atob('4pyTIMOgIGxhIG1vZGU=') は、「✓ à la mode」ではなく「⢠à la mode」を返します。 .

UTF-8 でエンコードされた Base64 文字列を適切にデコードするには、escape 関数と unescape 関数を使用する必要があります。この場合、window.atob(unescape(encodeURIComponent('✓ à la mode'))) は '4pyTIMOgIGxhIG1vZGU=' を返し、window.atob('4pyTIMOgIGxhIG1vZGU=') は '✓ à la mode' を返します。

base64 でエンコードされた受信ストリームを処理して utf-8 としてデコードされるようにするもう 1 つのオプションは、TextDecoder クラスを使用することです。このクラスは、base64 でエンコードされた文字列を UTF-8 文字列にデコードする方法を提供します。使用方法の例を次に示します:

<code class="javascript">const text = '4pyTIMOgIGxhIG1vZGU=';
const decoder = new TextDecoder('utf-8');
const decodedText = decoder.decode(Uint8Array.from(atob(text)));
console.log(decodedText); // '✓ à la mode'</code>
ログイン後にコピー

以上がJavascript の「atob」が UTF-8 Base64 文字列を適切にデコードできないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート