首页 > 解决方案 > 如何使用离子角度项目的插件将音频文件转换为 base64

问题描述

我正在尝试从媒体捕获离子插件中获取录音并将文件转换为 base64 字符串。我附上了适用于 Android 但不适用于 IOS 或 Microsoft 的代码。

public captureAudio(name: string, notes: string): void {

    this.mediaCapture.captureAudio().then(res => {
        var filePath = res[0].fullPath;

        this.getBase64StringByFilePath(filePath)
            .then((res) => {
                var base64Only = res.slice(34);
                //do something with base64 string
            });
    });
}

public getBase64StringByFilePath(fileURL: string): Promise<string> {

    return new Promise((resolve, reject) => {
        this.base64.encodeFile(fileURL).then((base64File: string) => {
            resolve(base64File);
        }, (err) => {
            console.log(err);
        });
    })
}

我注意到在我使用的 base64 转换插件中指出:

“获取任何图像的base64编码的插件,可以为android的任何文件检索Base64,但仅支持iOS图像”

还有其他选择吗?我们也研究了下面的文件插件,但在发送它想要的确切文件路径时遇到了麻烦(它要么不返回任何内容,要么返回错误)。我们还尝试了使用 getUserMedia 的更原生的 javascript 解决方案,但由于安全性,这在 IOS 上也不起作用。

使用的插件:

标签: angularionic-frameworkpluginsbase64

解决方案


此功能已从在线教程中获取 [ https://medium.com/@JordanBenge/ionic-converting-video-to-base64-a95158de3b2a]

读取 fileURI,使用 FileReader() 将其编码为 base64,然后我们必须对其进行修复。@param aAudioRecording 捕获视频的视频文件源 (URI)

    private async convertAudioToBase64(aAudioRecording): Promise<{}> {
        return new Promise(async resolve => {
            let lAudioSource: any = await this.file.resolveLocalFilesystemUrl(aAudioRecording);

            lAudioSource.file(resFile => {
                let lReader = new FileReader();
                lReader.readAsDataURL(resFile);
                lReader.onloadend = async (evt: any) => {
                    let lEncodingType: string;

                    if (this.dataProvider.getPlatform() == "ios") {
                        lEncodingType = "data:audio/mp3;base64,";
                    } else {
                        lEncodingType = "data:audio/x-m4a;base64,";
                    }

                    /*
                     * File reader provides us with an incorrectly encoded base64 string.
                     * So we have to fix it, in order to upload it correctly.
                     */
                    let lOriginalBase64 = evt.target.result.split(",")[1]; // Remove the "data:video..." string.
                    let lDecodedBase64 = atob(lOriginalBase64); // Decode the incorrectly encoded base64 string.
                    let lEncodedBase64 = btoa(lDecodedBase64); // re-encode the base64 string (correctly).
                    let lNewBase64 = lEncodingType + lEncodedBase64; // Add the encodingType to the string.

                    resolve(lNewBase64);
                };
            });
        });
    }

推荐阅读