简体   繁体   English

在表单中使用base64作为文件上传

[英]Using base64 in form to upload as file

I have this simple upload form to browse and upload an image. 我有这个简单的上传表单来浏览和上传图像。

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

But I'm using an image cropper, that outputs a base64 string and want to upload that instead. 但是我正在使用图像裁剪器,该图像裁剪器输出base64字符串,并希望上传该字符串。

Now the browser doesn't allow me to set the value of the file input to the string, it wants a file. 现在,浏览器不允许我将输入文件的值设置为字符串,它需要一个文件。

Now I replaced: 现在我替换了:

<input name="file" type="file" />

With: 附:

<input type="hidden" name="file" />

And handle the browsing/picking an image elsewhere. 并在其他地方处理浏览/挑选图像。

Now this somehow does upload a file, but the image is invalid, it's just a text-file with the base64 string inside it. 现在,该文件确实以某种方式上传了文件,但是图像无效,它只是一个文本文件,其中包含base64字符串。 Changing the type to file will fail the upload. 将类型更改为file将导致上传失败。

So I'm guessing it has to do with the base64 having to be converted to a readable file. 因此,我猜测这与必须将base64转换为可读文件有关。

After searching for converting base64 to file, I've tried: 搜索将base64转换为文件后,我尝试了:

blobData = atob(imageData)

But it errors: Uncaught InvalidCharacterError: Failed to execute 'atob' on 'Window': The string to be decoded is not correctly encoded. 但是它会出错: Uncaught InvalidCharacterError: Failed to execute 'atob' on 'Window': The string to be decoded is not correctly encoded. , while if I paste the string ( ....etc ) into the address-bar it displays correctly. ,如果我将字符串( ....etc....etc到地址栏中,则会正确显示。 Same when I try this: http://wiki.lenux.org/base64-string-to-blob-object/ I there's a lot of different ways to convert it, but I keep getting the error on atob that it's not correctly encoded. 尝试此操作时相同: http : //wiki.lenux.org/base64-string-to-blob-object/我有很多不同的方法来转换它,但是我不断在atob上收到错误消息,指出它的编码不正确。

I feel there must be a simple solution, because the browser already knows how to decode the string. 我觉得必须有一个简单的解决方案,因为浏览器已经知道如何解码字符串。

I've found: http://www.nixtu.info/2013/06/how-to-upload-canvas-data-to-server.html that outputs only the size and type of the image, but does not convert it. 我发现: http ://www.nixtu.info/2013/06/how-to-upload-canvas-data-to-server.html仅输出图像的大小和类型,但不进行转换。 And setting it as the value directly will result in a string: '[object Blob]` 并将其直接设置为值将产生一个字符串:'[object Blob]`

Going deeper down the rabbithole: Convert Blob to binary string synchronously this converts the blob to a Uint8Array , I think I'm very close, but I'm lost right now. 深入探讨: 将Blob同步转换为二进制字符串,这会将blob转换为Uint8Array ,我想我已经很接近了,但是我现在迷路了。

To be clear, I'm looking for a client-side solution, and don't want to use canvas or any other extra helper elements. 明确地说,我正在寻找一种客户端解决方案,并且不想使用canvas或任何其他额外的辅助元素。

You are trying to convert the URI scheme instead of the data. 您正在尝试转换URI方案而不是数据。 You will have to get at the encoded data of the URI to decode it. 您将必须获取URI的编码数据才能对其进行解码。

data URI syntax 数据URI语法

Let's take a look again at this img tag and its slightly disturbing syntax: 让我们再次看一下这个img标签及其稍微令人不安的语法:

 <img src="..." /> <img src =“ data:image / png; base64,iVBOR ...” /> 

You have: 你有:

  • data - name of the scheme data -方案名称
  • image/png - content type image/png内容类型
  • base64 - the type of encoding used to encode the data base64用于编码数据的编码类型
  • iVBOR... - the encoded data iVBOR...编码数据
  • some , and ; 一些和; and : sprinked for good measure 和:撒好

http://www.phpied.com/data-urls-what-are-they-and-how-to-use/ http://www.phpied.com/data-urls-what-are-they-and-how-to-use/

The easiest way would be to split on the comma. 最简单的方法是分割逗号。

var image =""
var decoded = atob(image.split(",")[1])

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM