是否可以将 uploadcollection 的对象转换为 xstring?

is it possible to convert uploadcollection's object into a xstring?

使用 sapui5 uploadcollection 在前端上传文件,然后使用 post 请求通过 ajax 发送...

我需要知道如何将从 uploadcollection 控件返回的对象转换为 xstring,然后我可以使用 ajax [= 将该 xstring(包含文件内容)发送到 sap 网关31=]方法。

知道我该怎么做吗?

现在我正在使用 uploadcollection 发送文件,一旦我上传附件,控件 returns 一个代表文件内容的对象。

我正在尝试使用 filereader 使这个对象成为 xstring:

                                                        //obtiene archivo
                                                        var file = files[i];

                                                        //Convierte archivo en binario
                                                        var reader = new FileReader();
                                                        reader.onload = function(readerEvt) {

                                                            var binaryString = readerEvt.target.result;
                                                            var base64 = btoa(binaryString);
                                                            var base64file; 

                                                            if(typeof base64file == "undefined" || typeof base64file == null){
                                                                base64file = base64; 
                                                            }else{
                                                              base64file = base64file +'new'+base64;
                                                            }
                                                        };
                                                        reader.readAsBinaryString(file);

                                                        console.log(file)

但这只适用于图像类型的文件,当我尝试使用 ajax 发送其他文件(如 pdf、.doc 等)时出现以下错误。

"The Data Services Request could not be understood due to malformed syntax"。

知道如何将这些文件转换成 xstring 数据吗?

看看这个例子。希望这有帮助。

查看

<u:FileUploader change="onChange" fileType="pdf" mimeType="pdf" buttonText="Upload" />

控制器

convertBinaryToHex: function(buffer) {
        return Array.prototype.map.call(new Uint8Array(buffer), function(x) {
            return ("00" + x.toString(16)).slice(-2);
        }).join("");
    },


onChange: function(oEvent){
    var that = this;
    var reader = new FileReader();
    var file = oEvent.getParameter("files")[0];

    reader.onload = function(e) {
        var raw = e.target.result;
        var hexString = that.convertBinaryToHex(raw).toUpperCase(); 
        // DO YOUR THING HERE            
    };

    reader.onerror = function() {
        sap.m.MessageToast.show("Error occured when uploading file");
    };

    reader.readAsArrayBuffer(file);
},

每次通过控件上传文件时,我都是通过填充一个数组来解决的,

                    change: function(oEvent) {


                        //Get file content
                        file = oEvent.getParameter("files")[0];

                        //Prepare data for slug
                        fixname = file.name;
                        filename = fixname.substring(0, fixname.indexOf("."));
                        extension = fixname.substring(fixname.indexOf(".") + 1);

                        //fill array with uploaded file
                        var fileData = {
                            file: file,
                            filename: filename,
                            extension: extension
                        }
                        fileArray.push(fileData);

                    },

然后我对该数组进行了循环 post 我使用 ajax 方法 post.

保留在那里的每个文件
                                                $.each(fileArray, function(j, valor) {

                                                    //get file
                                                    file = fileArray[j].file;

                                                    //get file lenght
                                                    var numfiles = fileArray.length;


                                                    //Convert file to binary
                                                    var reader = new FileReader();
                                                    reader.readAsArrayBuffer(file); 
                                                    reader.onload = function(evt) {
                                                        fileString = evt.target.result; 

                                                        //get and make slug
                                                        filename = fileArray[j].filename;
                                                        extension = fileArray[j].extension;
                                                        slug = documento + '/' + filename + '/' + extension;


                                                        //User url service
                                                        var sUrlUpload = "sap url";
                                                        runs++;

                                                        //Post files
                                                        jQuery.ajax({});
                                                    }
                                                });