2

I tried to get the image from clipboard when I press ctrl+v on a page, with the code from a gist, which will console.log the image content it gets.

I found the image content is a long base64 string with a special prefix:



How to decode it to binary? I tried to remove the prefix data:image/png;base64, and use a base64 library to decode the rest into binary, and save it to a image.png file. But the file can't be displayed, with invalid format error.

But if I paste the whole string to http://base64online.org/decode/, it can play the image as well.

The base64 library I used is https://github.com/wstrange/base64, and my code is:

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);

I don't know where is wrong :(

4

3 回答 3

4

尝试使用cryptoDart SDK 中的包。这会创建一个可以正常打开的 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的库,也在 README 中注明:

已弃用

注意:Dart SDK 现在包含一个带有 url 安全选项的 Base64 编解码器。除非您需要流式传输支持,否则您应该使用 SDK 方法,因为它们的速度稍快一些。

请参阅 CryptoUtils

另请参阅如何本地转换字符串 -> base64 和 base64 -> 字符串

于 2013-07-17T14:19:47.807 回答
3

解码为字符串然后写入字节有效:

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);
于 2013-07-17T14:27:40.890 回答
1

最简单的方法是:

import 'dart:convert';

final result = base64Decode(stringValue);
于 2020-05-05T10:49:25.500 回答