在javascript中使用AJAX从SD卡在FB上发布图像

在javascript中使用AJAX从SD卡在FB上发布图像,javascript,Javascript,我几乎尝试了所有可能的方法和代码示例。getEncodeImage正在返回一个常量base64string,我已经在w3schools.com上通过尝试自己返回一个图像检查了它。Base64Binary是我在一篇文章中读到的另一个函数,其中提到它是通过解码将图像发布到facebook墙上的方式实现的。若我传递了JSON.stringify(decodedPng),我得到的错误URL格式不正确,若我忽略了JSON.stringify,那个么这个错误就是非法调用 cmdPost.addEventLi

我几乎尝试了所有可能的方法和代码示例。getEncodeImage正在返回一个常量base64string,我已经在w3schools.com上通过尝试自己返回一个图像检查了它。Base64Binary是我在一篇文章中读到的另一个函数,其中提到它是通过解码将图像发布到facebook墙上的方式实现的。若我传递了JSON.stringify(decodedPng),我得到的错误URL格式不正确,若我忽略了JSON.stringify,那个么这个错误就是非法调用

cmdPost.addEventListener("click", function() {
        outputlog("Post to wall...");



        //added
        var canv = document.querySelector('img#smallImage');

       var imgData = getBase64Image(canv);

        try {

            var testimage = getEncodedImage();

            //var testimage = getEncodedImage();
            var encodedPng = testimage.substring(testimage.indexOf(',') + 1, testimage.length);
            var decodedPng = Base64Binary.decode(encodedPng);

            //var encodedPng = imgData.substring(imgData.indexOf(',') + 1, imgData.length);
            //var decodedPng = Base64Binary.decode(encodedPng);

            //alert('decodedPng=' + decodedPng);

            $.oajax({
                type: "POST",
                url: "https://graph.facebook.com/me/feed",
                jso_provider: "facebook",
                //commented and added below by mubashar
                //jso_scopes: ["read_stream", "publish_stream"],
                jso_scopes: ["read_stream", "publish_stream", "publish_actions"],            //, "publish_actions"
                jso_allowia: true,
                dataType: 'json',
                data: {
                    message: "Testing Some Application Ignore My Status for few days!",

                    //source: "http://www.info2gsm.com/VH.png"
                    source: decodedPng
                    //source: JSON.stringify(decodedPng)
                },
                success: function (data) {
                    alert('posted');
                    outputlog("Post response (facebook):");
                    outputlog(data);
                },
                error: function (e) {
                    alert('not posted');
                    outputlog(e);
                }
            });

        } catch (e) {
            alert('error occured = '+ e);
        }



    });
};





function getEncodedImage() {
    return ""

    //return "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"
}


var Base64Binary = {
    _keyStr: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",

    /* will return a  Uint8Array type */
    decodeArrayBuffer: function (input) {
        var bytes = (input.length / 4) * 3;
        var ab = new ArrayBuffer(bytes);
        this.decode(input, ab);

        return ab;
    },

    decode: function (input, arrayBuffer) {
        //get last chars to see if are valid
        var lkey1 = this._keyStr.indexOf(input.charAt(input.length - 1));
        var lkey2 = this._keyStr.indexOf(input.charAt(input.length - 2));

        var bytes = (input.length / 4) * 3;
        if (lkey1 == 64) bytes--; //padding chars, so skip
        if (lkey2 == 64) bytes--; //padding chars, so skip

        var uarray;
        var chr1, chr2, chr3;
        var enc1, enc2, enc3, enc4;
        var i = 0;
        var j = 0;

        if (arrayBuffer)
            uarray = new Uint8Array(arrayBuffer);
        else
            uarray = new Uint8Array(bytes);

        input = input.replace(/[^A-Za-z0-9\+\/\=]/g, "");

        for (i = 0; i < bytes; i += 3) {
            //get the 3 octects in 4 ascii chars
            enc1 = this._keyStr.indexOf(input.charAt(j++));
            enc2 = this._keyStr.indexOf(input.charAt(j++));
            enc3 = this._keyStr.indexOf(input.charAt(j++));
            enc4 = this._keyStr.indexOf(input.charAt(j++));

            chr1 = (enc1 << 2) | (enc2 >> 4);
            chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
            chr3 = ((enc3 & 3) << 6) | enc4;

            uarray[i] = chr1;
            if (enc3 != 64) uarray[i + 1] = chr2;
            if (enc4 != 64) uarray[i + 2] = chr3;
        }

        return uarray;
    }
}
cmdPost.addEventListener(“单击”,函数(){
输出日志(“贴到墙上…”);
//增加
var canv=document.querySelector('img#smallImage');
var imgData=getBase64Image(canv);
试一试{
var testimage=getEncodedImage();
//var testimage=getEncodedImage();
var encodedPng=testimage.substring(testimage.indexOf(',')+1,testimage.length);
var decodedPng=Base64Binary.decode(encodedPng);
//var encodedPng=imgData.substring(imgData.indexOf(',')+1,imgData.length);
//var decodedPng=Base64Binary.decode(encodedPng);
//警报('decodedPng='+decodedPng);
$.oajax({
类型:“POST”,
url:“https://graph.facebook.com/me/feed",
jso_提供商:“facebook”,
//穆巴沙尔在下面评论并添加
//jso_作用域:[“读取流”、“发布流”],
jso_作用域:[“读取_流”、“发布_流”、“发布_操作”]、/、“发布_操作”
jso_allowia:没错,
数据类型:“json”,
数据:{
消息:“测试某些应用程序会忽略我的状态几天!”,
//来源:“http://www.info2gsm.com/VH.png"
资料来源:decodedPng
//来源:JSON.stringify(decodedPng)
},
成功:功能(数据){
警报(“已发布”);
outputlog(“发布响应(facebook):”;
输出日志(数据);
},
错误:函数(e){
警报(“未发布”);
输出日志(e);
}
});
}捕获(e){
警报(“发生错误=”+e);
}
});
};
函数getEncodedImage(){
回来"数据:image/jpeg;base64/9j/4AAQSkZJRgABAQEAYABgAAD/2wbdaaaibaqibaqibaqicagicawdawmdawyebamwyhbwcgbwcicqsjcagccachcg0kcgmdawwwkodw0mdgsmdaz/2wbdaaqicagydawydaydawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmdawmd2.这一研究的目的是一种新的研究方法,一种新的研究方法,一种新的研究方法,一种新的研究方法,一种新的研究方法,一种新的研究方法,一种新的研究方法,一种新的研究方法,一种新的研究方法,一种新的研究方法,一种新的研究方法,一种新的研究方法,一种新的研究方法,一种新的研究方法,一种新的研究,一种新的研究方法,一种新的中国的中国中国的中国的中国的研究的一种新的研究方法,在一种新的中国中国的中国的中国政府的一级(2 2-2-2 2-8-6-8级中国中国政府在一个中国中国的中国政府在一个中国的研究中,6-8个中国政府在该文文文文中,即6-8 8个中国的中国中国的8 8 8 8个中国作为作为作为作为作为作为一个中国的一个中国的一个中国的中国的ZG5OKN研究结果表明,该文是一篇关于某一方面的研究成果。该文是一篇关于某一方面的研究成果。该方面的研究成果是一篇关于某一领域的研究成果。该领域的研究成果是一篇关于某一领域的研究成果。该领域的研究成果是一篇关于该领域的研究成果。该领域的研究成果是一篇关于该领域的研究成果。该领域的研究成果是一篇关于该领域的一份关于该领域的研究的2 2 2 2号文的2号文的研究。2号文2号文是一份关于某一份关于该领域的2号文2号文的研究2号文的2号文的研究。2号文2号文2号文件,即关于某一份关于某一份关于某一份关于该领域的研究2号文的2号文的研究2号文的2号文的2号文的研究的研究,即关于某某某某某某某某某某某某某某某某某某某某某某某某某一Q2OPYYP1OZ+FmZLHxwD+dQS5.一个5级文文(一个5级文(一个5级文(一个5级文(一个5级文(一个5级文(一个5级文(一个5级文(一个5级文(一个5级文(一个5级文(一个5级文(一个2级文(一个2级文(一个2级文)2级文(2)6级文(2级文)2级文)2级文(2)2级文(2级文)2级文)2级文(2级文(2)2级文)2级文(2级文)2级文)2级文(2级文(2级文)2级文)2级文(2级文)2级文(2级文)2级文(2级文)2级文(2级文)2级文)2级文2级文(2级文2级文2级文2级文2级文2级文2级文2级文2级文7DHWHUPCESTVPOM6JBPDYXWOGSI3U5WM2)2)2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 MUJGADJPKC9A+BP2+7tfi34/u/H82.一个非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的非政府的K7N4GXD34U8SQ69ZAC2N2FGKO4+10+10+10+10+10+10+10+10+10+10+10+10+10+10+10+10+10+6+GJJQ+6+6 GZZZZGGGGGGXXXXGGGGGGXXXXXTTTTTTTTTTTTZZZZZZZZZZZZZZZZZZZZZZZZZZZGGGGGGGZGGGGGGGGGGGGGGGGGZZZZZZZGGGGGGGGGGGGGXXXXXXXXXXXXXGGGGGGGGGGGGGGGGGGGGGXXXXXXXXXXXXXXXGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGGWnsFuvBMMQCCOSK+xylqVBch6+Wyi6SsUrnRbu0zvtp1A7lDi本文的研究对象是一个关于某一领域的一个关于某一领域的一个关于某一领域的一个关于某一领域的知识点(FKKKKKKKKKKKKKKKKJJJJJJJJJJJJJJJJJJJJJJJJKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKFFFFFBBBBBBBBBBBKKKKKKKKKBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKKK4I/4Kffsj2nilWHR81PK0ZY2ENVxDYXY目前,中国的一家报纸上的一家报纸上的一家报纸上的一家报纸上的一家报纸上的一家报纸上的一家报纸上的一家报纸上的一家报纸上的一家报纸上的一家报纸上的一家报纸上的一家报纸上的一家报纸上的一家报纸上的一家报纸上的一家报纸上一家报纸上一家报纸上的一家报纸上一家报纸上的一家报纸上一家报纸上的一家报纸上的一家报纸上的一家报纸上一家公司的一家报纸上一家报纸上的一家公司的一家报纸上一家公司的一家公司的一家公司的一家公司的一家公司的一家公司,一家公司的一家公司的一家公司的一家公司的一家公司,一家公司的一家公司的一家(wwwwwwwwwwwwwwwwwwwwwwwwwwwwww8 8 8 8 8 8 CMCPARECWWOPGC9AOBX9KLSFCIIXEKPH/AMESv+一个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8个8 ML3MiIGRYTPMJFG8EVYEc4PTg49aKKpGaSuVpJMt0xxULMScUUVPUtDaR/umiigY3caKKKDQ//9k=”
//返回“/9j”/
if (XMLHttpRequest.prototype.sendAsBinary === undefined) {
    XMLHttpRequest.prototype.sendAsBinary = function (string) {
            var bytes = Array.prototype.map.call(string, function (c) {
                return c.charCodeAt(0) & 0xff;
            });
            this.send(new Uint8Array(bytes).buffer);
        };
    };

    cmdPost.addEventListener("click", function () {

        jso_ensureTokens({
            "facebook": ["read_stream", "publish_stream", "publish_actions"]
        });


        outputlog("Post to wall...");


        try {


            drawCanvas();

            postCanvasToFacebook();

        } catch (e) {
            alert('error occured = '+ e);
        }



    });
};




function postCanvasToFacebook() {

    var data = canvas.toDataURL("image/png");
    var encodedPng = data.substring(data.indexOf(',') + 1, data.length);
    var decodedPng = Base64Binary.decode(encodedPng);

    var tok = jso_getToken("facebook");
    postImageToFacebook(tok, "info2gsm", "image/png", decodedPng, "www.info2gsm.com");
};



function postImageToFacebook(authToken, filename, mimeType, imageData, message) {

    try {
        // this is the multipart/form-data boundary we'll use
        var boundary = '----ThisIsTheBoundary1234567890';
        // let's encode our image file, which is contained in the var
        var formData = '--' + boundary + '\r\n'
        formData += 'Content-Disposition: form-data; name="source"; filename="' + filename + '"\r\n';
        formData += 'Content-Type: ' + mimeType + '\r\n\r\n';
        for (var i = 0; i < imageData.length; ++i) {
            formData += String.fromCharCode(imageData[i] & 0xff);
        }
        formData += '\r\n';
        formData += '--' + boundary + '\r\n';
        formData += 'Content-Disposition: form-data; name="message"\r\n\r\n';
        formData += message + '\r\n'
        formData += '--' + boundary + '--\r\n';

        var xhr = new XMLHttpRequest();
        xhr.open('POST', 'https://graph.facebook.com/me/photos?access_token=' + authToken, true);

        xhr.onload = xhr.onerror = function () {

        };
        xhr.setRequestHeader("Content-Type", "multipart/form-data; boundary=" + boundary);
        xhr.sendAsBinary(formData);
        alert('Posted Successfully.');
    } catch (e) {
        alert('Not Posted Error Occured.'+ e);
    }




};



var canvas;
var context;
var centerX;
var img;
var authToken;
function drawCanvas() {

    canvas = document.getElementById("canvas1");
    context = canvas.getContext("2d");

    img = document.querySelector('img#smallImage');

    context.drawImage(img, 0, 0,430,280);
        context.fillStyle = "rgb(231,222,201)";
        centerX = canvas.width / 2;
        context.textAlign = 'center';
        context.font = 'italic bold 16px sans-serif';
        context.fillText("Model = will appear here", centerX, 70);
        context.fillText("Price = will appear here.", centerX, 130);
        context.fillText("Others = will appear here.", centerX, 190);
};


var Base64Binary = {
    _keyStr: "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",

    /* will return a  Uint8Array type */
    decodeArrayBuffer: function (input) {
        var bytes = (input.length / 4) * 3;
        var ab = new ArrayBuffer(bytes);
        this.decode(input, ab);

        return ab;
    },

    decode: function (input, arrayBuffer) {
        //get last chars to see if are valid
        var lkey1 = this._keyStr.indexOf(input.charAt(input.length - 1));
        var lkey2 = this._keyStr.indexOf(input.charAt(input.length - 2));

        var bytes = (input.length / 4) * 3;
        if (lkey1 == 64) bytes--; //padding chars, so skip
        if (lkey2 == 64) bytes--; //padding chars, so skip

        var uarray;
        var chr1, chr2, chr3;
        var enc1, enc2, enc3, enc4;
        var i = 0;
        var j = 0;

        if (arrayBuffer)
            uarray = new Uint8Array(arrayBuffer);
        else
            uarray = new Uint8Array(bytes);

        input = input.replace(/[^A-Za-z0-9\+\/\=]/g, "");

        for (i = 0; i < bytes; i += 3) {
            //get the 3 octects in 4 ascii chars
            enc1 = this._keyStr.indexOf(input.charAt(j++));
            enc2 = this._keyStr.indexOf(input.charAt(j++));
            enc3 = this._keyStr.indexOf(input.charAt(j++));
            enc4 = this._keyStr.indexOf(input.charAt(j++));

            chr1 = (enc1 << 2) | (enc2 >> 4);
            chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
            chr3 = ((enc3 & 3) << 6) | enc4;

            uarray[i] = chr1;
            if (enc3 != 64) uarray[i + 1] = chr2;
            if (enc4 != 64) uarray[i + 2] = chr3;
        }

        return uarray;
    }
}