0

我正在core_files_upload使用这个脚本将moodle api与节点js一起使用

const { CallService } = require("../MoodleWS")

var Upload = async function(userid, file) {
    var base64 = await toBase64(file)
        .then(r => {
            return r;
        })
        .catch((e) => {
            console.log(e)
        });
    console.log(base64);
    var param = {
        itemid: 0,
        instanceid: userid,
        filearea: 'draft',
        filecontent: base64,
        component: 'user',
        filepath: '/',
        filename: file.name,
        contextlevel: 'user'
    }
    // return promise calling web service, basically returned axios
    return CallService('POST', 'core_files_upload', false, null, param);
}

const toBase64 = file => new Promise((resolve, reject) => {
    const reader = new FileReader();
    reader.readAsDataURL(file);
    reader.onload = () => resolve(reader.result);
    reader.onerror = () => reject(reader.error);
})

module.exports = { Upload }

函数返回成功并上传文件,我检查了上传的文件大小与原始文件相同,不幸的是我无法打开文件并一直说如下图

在此处输入图像描述

并且图像也无法显示

在此处输入图像描述

上传的 base64 也有 mime/type 标题,就像data:application/pdf;base64,JVBERi0xLjQNJeL...我真的不知道出了什么问题。当我尝试使用moodle的本机网络版本上传文件时,文件正确上传。所以有人可以帮忙吗?谢谢

4

1 回答 1

0

所以事实证明我不需要包含来自 base64 的 mime/type。所以我只是删除data:application/pdf;base64并修改了我的参数,所以它变得像

var base64 = await toBase64(file)
        .then(r => {
            return r;
        })
        .catch((e) => {
            console.log(e)
        });
    var param = {
        itemid: 0,
        instanceid: userid,
        filearea: 'draft',
        filecontent: base64.split(',')[1],
        component: 'user',
        filepath: '/',
        filename: file.name,
        contextlevel: 'user'
    }

于 2021-03-06T06:42:50.297 回答