当我在页面上按ctrl+v
时,我尝试从剪贴板中获取图片,其中包含来自a gist的代码,其中console.log
将获得图像内容。
我发现图像内容是一个带有特殊前缀的长base64字符串:

如何将其解码为二进制?我尝试删除前缀data:image/png;base64,
并使用base64库将其余部分解码为二进制文件,并将其保存到image.png
文件中。但是文件无法显示,invalid format
错误。
但如果我将整个字符串粘贴到http://base64online.org/decode/,它也可以播放图像。
我使用的base64库是https://github.com/wstrange/base64,我的代码是:
import 'package:base64_codec/base64_codec.dart';
var body = /* the long str above */;
var prefix = "data:image/png;base64,";
var bStr = body.substring(prefix.length);
var bs = Base64Codec.codec.decodeList(bStr.codeUnits);
var file = new File("image.png");
file.writeAsBytesSync(bs);
我不知道哪里出错:(
答案 0 :(得分:4)
尝试使用Dart SDK中的crypto
包。这会创建一个打开正常的image.png(我相信这是这个图像... )
library foo;
import 'package:crypto/crypto.dart';
import 'dart:io';
void main() {
var body = "... snip";
var prefix = "data:image/png;base64,";
var bStr = body.substring(prefix.length);
var bytes = CryptoUtils.base64StringToBytes(bStr); // using CryptoUtils from Dart SDK
var file = new File("image.png");
file.writeAsBytesSync(bytes);
}
您需要将crypto
添加到pubspec.yaml
:
dependencies:
crypto: any
在https://github.com/wstrange/base64链接的图书馆,也在自述文件中注明:
已过时
注意:Dart SDK现在包含一个带有url安全选项的Base64编解码器。除非您需要流媒体支持,否则您应该使用SDK方法,因为它们稍微快一些。
请参阅CryptoUtils
另见How to native convert string -> base64 and base64 -> string
答案 1 :(得分:2)
以字符串形式解码,然后写入字节:
var prefix = "data:image/png;base64,";
var bStr = body.substring(prefix.length);
var bs = Base64Codec.codec.decodeString(bStr);
var file = new File("image.png");
file.writeAsBytesSync(bs.codeUnits);
答案 2 :(得分:1)
最简单的方法是:
import 'dart:convert';
final result = base64Decode(stringValue);