angular - 如何使用离子角度项目的插件将音频文件转换为 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 上也不起作用。
使用的插件:
解决方案
此功能已从在线教程中获取 [ 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);
};
});
});
}