【问题标题】:FileReader - How to change the character encoding from UTF-8 to ANSIFileReader - 如何将字符编码从 UTF-8 更改为 ANSI
【发布时间】:2020-08-23 02:16:25
【问题描述】:

我正在尝试通过为产品提供的 API 将文件上传到 Google Drive。但是,我认为编码存在问题 - 特别是 FileReader.readAsText() 函数。

我尝试为编码添加可选参数,使其看起来像r.readAsText(f,'ANSI'),但它似乎不起作用。

readAsText() 函数出于某种奇怪的原因默认为 UTF-8 编码。当我尝试使用 UTF-8 编码上传图像文件时,它们已损坏且无法正常打开。

 function readFile(evt) {
            var fData = [];
            var f = evt.target.files[0];
            if (f) {
                var r = new FileReader();
                r.readAsText(f);
                fData.unshift(f.name, f.type);
                var myInt = setInterval(function() {
                    if (r.readyState == 2) {
                        fData.push(r.result);
                        uploadFiles(fData);
                        clearInterval(myInt);
                    }
                }, 50);
            } else {
                alert("Failed to load file");
            }

        }


        function uploadFiles(dataArray,callback) {
                const boundary = '-------314159265358979323846';
                const delimiter = "\r\n--" + boundary + "\r\n";
                const close_delim = "\r\n--" + boundary + "--";

                const contentType = 'application/json';

                var metadata = {
                    'name': dataArray[0],
                    'mimeType': dataArray[1]
                };

                var multipartRequestBody =
                    delimiter +
                    'Content-Type: application/json\r\n\r\n' +
                    JSON.stringify(metadata) +
                    delimiter +
                    'Content-Type: ' + contentType + '\r\n\r\n' +
                    dataArray[2] +
                    close_delim;

                var request = gapi.client.request({
                    'path': '/upload/drive/v3/files',
                    'method': 'POST',
                    'params': { 'uploadType': 'multipart' },
                    'headers': {
                        'Content-Type': 'multipart/related; boundary="' + boundary + '"'
                    },
                    'body': multipartRequestBody
                });
                if (!callback) {
                    callback = function(file) {
                        console.log(file)
                    };
                }
                request.execute(callback);
        }

        document.getElementById('upFile').addEventListener('change', readFile, false);

【问题讨论】:

    标签: javascript google-api google-apis-explorer


    【解决方案1】:

    您想通过 JavaScript 使用 Drive API 将文件上传到 Google Drive。这个解决方法怎么样?在此解决方法中,文件被转换为 base64 并上传到 Google Drive。

    修改点:

    • 使用readAsDataURL() 而不是readAsText()
    • 在请求正文中将数据定义为 base64。

    修改后的脚本:

    请修改以下两部分。

    1. 来自:
    r.readAsText(f);
    
    1. 至:
    r.readAsDataURL(f);
    
    2. 来自:
    var multipartRequestBody =
        delimiter +
        'Content-Type: application/json\r\n\r\n' +
        JSON.stringify(metadata) +
        delimiter +
        'Content-Type: ' + contentType + '\r\n\r\n' +
        dataArray[2] +
        close_delim
    
    2. 至:
    var multipartRequestBody =
        delimiter +
        'Content-Type: application/json\r\n\r\n' +
        JSON.stringify(metadata) +
        delimiter +
        'Content-Type: ' + contentType + '\r\n' + // Modified
        'Content-Transfer-Encoding: base64\r\n\r\n' + // Added
        dataArray[2].split(",")[1] + // // Modified
        close_delim
    

    参考:

    我也遇到过和你一样的情况。当时我用base64解决了这个问题。

    【讨论】:

    • 嘿!感谢您的回答,这有效。我之前尝试过 readAsDataURL() 但我认为最终真正使它起作用的是 Content-Transfer-Encoding: base64 header
    • @TKD21 感谢您的回复。我很高兴你的问题得到了解决。是的。我之前也和你有过同样情况的问题。所以当我看到你的问题时,我可以记住这个解决方案。也谢谢你。
    猜你喜欢
    • 1970-01-01
    • 2020-05-07
    • 1970-01-01
    • 2019-10-25
    • 1970-01-01
    • 2010-12-08
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多