imgur image uploading will not work with base64 data?
Asked Answered
K

1

5

I've been trying for more than 3 hours to get imgur to accept base 64 data to absolutely no avail, I've confirmed the data is correct, I've confirmed that I can send to imgur using a url image, I just can't get it to work. The code I'm using is as follows:

$(document).ready(function(){
            function readImage(input) {
                var FR= new FileReader();
                FR.onload = function(e) {
                    console.log(e.target.result);
                    $.ajax({
                                url: 'https://api.imgur.com/3/image',
                                type: 'post',
                                headers: {
                                    Authorization: 'Client-ID 40dbfe0cfea73a7'
                                },
                                data: {
                                    image: e.target.result
                                },
                                dataType: 'json',
                                success: function(json) {
                                    console.log(json);
                                },
                                error: function(json) {
                                    console.log(json);
                                }
                            });
                };       
                FR.readAsDataURL( input );
            }
    });

input is the form input that i'm getting from dropzone.js, and an example of the base64 data is :



I'm getting a 400 error which means( as per the docs that A) I'm leaving out a parameter, or using a invalid value. or B) the image is corrupt or has invalid format. This makes no sense to me, because copying that base64 data into a browser works fine, the Authorization works fine, And I know I can upload if the image is a url. So I'm not sure what's going on here! If you need any more data, please tell me and I'll update this question ASAP! Thanks so much you guys!

Kristynkrock answered 11/12, 2013 at 7:20 Comment(2)
Replace "data:image/png;base64," with empty string, refer jsfiddle.net/jasdeepkhalsa/L5HmW and #15710015Durga
Wow that worked, I feel like a moron, thank you so much! I'll accept the answer if you put it. :)Kristynkrock
D
13

You have to replace data:image/png;base64, with an empty string like this:

return dataURL.replace(/^data:image\/(png|jpg);base64,/, "");

Demo in JSFiddle

See Also: Save base64-encoded image with AJAX request in PHP

Durga answered 11/12, 2013 at 7:41 Comment(1)
I have done this, and I just get an empty image back from imgur!! Do you know what else it could be? My ajax call is: url: 'api.imgur.com/3/image', headers: {"Authorization": "Client-ID [client id here]"}, type: 'POST', data: {'image': img, 'type': 'base64', 'title': imgurTitle}, success: function(result) { }Salutation

© 2022 - 2024 — McMap. All rights reserved.