首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >正在将blob URL上载到Imgur?

正在将blob URL上载到Imgur?
EN

Stack Overflow用户
提问于 2018-10-17 06:47:31
回答 1查看 1.2K关注 0票数 2

我正在尝试将blob url上传到imgur api:

https://apidocs.imgur.com/#c85c9dfc-7487-4de2-9ecd-66f727cf3139

它在文档中清楚地说明它可以是:binary filebase64url

我的网址(示例):blob:http://localhost:8080/7e44709-093d-4a4-b167-a3fdfc63a8e

代码语言:javascript
代码运行次数:0
运行
复制
formData.append('image', 'blob:http://localhost:8080/7e44709-093d-4a4-b167-a3fdfc63a8e');
formData.append('type', 'URL');

然而,我从imgur api得到了400错误:

代码语言:javascript
代码运行次数:0
运行
复制
{"data":{"error":
"Invalid URL (blob:http:\/\/localhost:8080\/7e44729-093d-4aa4-167-a3fdef3a8e)",
"request":"\/3\/image","method":"POST"},"success":false,"status":400}

期待帮助,为什么它会失败,以及如何正确上传它。谢谢你

EN

回答 1

Stack Overflow用户

发布于 2018-10-17 06:53:54

图像需要转换为base64格式,然后从base64格式转换为二进制格式。这是使用.toDataURL()dataURItoBlob()完成的

Img => Base64 =>二进制文件

代码语言:javascript
代码运行次数:0
运行
复制
function imgToURI() {
  // Convert image to Base64
  var img = snap.toDataURL();
  // Convert Base64 image to binary
  var file = dataURItoBlob(img);
}

function dataURItoBlob(dataURI) {
// convert base64/URLEncoded data component to raw binary data held in a string
var byteString;
if (dataURI.split(',')[0].indexOf('base64') >= 0)
    byteString = atob(dataURI.split(',')[1]);
else
    byteString = unescape(dataURI.split(',')[1]);
// separate out the mime component
var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0];
// write the bytes of the string to a typed array
var ia = new Uint8Array(byteString.length);
for (var i = 0; i < byteString.length; i++) {
    ia[i] = byteString.charCodeAt(i);
}
return new Blob([ia], {type:mimeString});
}

如果需要的话,你可以在twitter上停下来,在我的例子中,我需要再次转换成二进制,这样我就可以在不使用db的情况下将数据传递到base64 (使用OAuth)。事实证明,你可以在推特上发布二进制文件,这非常酷,twitter会将其转换成图片。

I created a blog post about this a few years ago

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52844975

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档