我有这个简单的上传表单来浏览和上传图片。
<form action="https://storage.googleapis.com/YOUR_BUCKET_NAME"
method="post" enctype="multipart/form-data">
<input name="key" type="text" value="objectName.txt" /><br/>
<input name="file" type="file" /><br/>
<input type="submit" value="Upload!" />
</form>
但是我使用的是图片裁剪器,它会输出一个base64
字符串,并希望上传它。
现在浏览器不允许我将文件输入的值设置为字符串,它需要一个文件。
现在我换了:
<input name="file" type="file" />
使用:
<input type="hidden" name="file" />
并在其他地方处理浏览/挑选图像。
现在以某种方式 上传文件,但图片无效,它只是一个文本文件,里面有base64
字符串。将类型更改为file
将无法上传。
所以我猜测它与base64
必须转换为可读文件有关。
搜索将base64转换为文件后,我尝试过:
blobData = atob(imageData)
但是错误:Uncaught InvalidCharacterError: Failed to execute 'atob' on 'Window': The string to be decoded is not correctly encoded.
,而如果我将字符串(....etc
)粘贴到地址栏中,则会正确显示。
我尝试这样做时相同:http://wiki.lenux.org/base64-string-to-blob-object/
我有很多不同的方式来转换它,但我一直在atob
上收到错误,因为它没有正确编码。
我觉得必须有一个简单的解决方案,因为浏览器已经知道如何解码字符串。
我发现:http://www.nixtu.info/2013/06/how-to-upload-canvas-data-to-server.html仅输出图像的大小和类型,但不会转换它。并将其直接设置为值将产生一个字符串:&#39; [object Blob]`
深入了解rabbithole:Convert Blob to binary string synchronously这会将blob
转换为Uint8Array
,我觉得我非常接近,但我现在迷失了。
要明确的是,我正在寻找客户端解决方案,并且不想使用canvas
或任何其他额外帮助元素。
答案 0 :(得分:1)
您正在尝试转换URI方案而不是数据。您必须获取URI的编码数据才能对其进行解码。
数据URI语法
让我们再看看这个img标签及其标签 有点令人不安的语法:
<img src="..." />你有:
data
- 计划名称image/png
- 内容类型base64
- 用于编码数据的编码类型iVBOR...
- 编码数据- 一些,和;并且:为了好的措施而撒
http://www.phpied.com/data-urls-what-are-they-and-how-to-use/
最简单的方法是分割逗号。
var image =""
var decoded = atob(image.split(",")[1])