在Angular中使用base64编码上传/存储/下载文件可以按照以下步骤进行:
上传文件: 首先,将文件转换为base64编码。可以使用FileReader对象的readAsDataURL方法来实现:
// 选择文件
const fileInput = document.getElementById('fileInput');
const file = fileInput.files[0];
// 读取文件为base64编码
const reader = new FileReader();
reader.onloadend = () => {
const base64String = reader.result.toString().split(',')[1];
// 在这里发送base64String到服务器
};
reader.readAsDataURL(file);
存储base64编码的文件: 在服务器端接收到base64编码的文件后,可以将其存储为文件:
const fs = require('fs');
const base64Data = req.body.base64String;
const filename = 'path/to/file.png'; // 指定存储位置和文件名
fs.writeFile(filename, base64Data, 'base64', (err) => {
if (err) {
console.error(err);
} else {
console.log('文件已保存');
}
});
下载base64编码的文件: 如果需要从服务器端下载base64编码的文件,可以使用以下代码:
const fs = require('fs');
const base64Data = fs.readFileSync('path/to/file.png', 'base64');
// 将base64编码的数据作为响应发送给客户端
res.send(base64Data);
在客户端,可以使用以下代码将base64编码的数据转换为文件并下载:
// 将base64编码的数据转换为Blob对象
const byteCharacters = atob(base64String);
const byteArrays = [];
for (let offset = 0; offset < byteCharacters.length; offset += 512) {
const slice = byteCharacters.slice(offset, offset + 512);
const byteNumbers = new Array(slice.length);
for (let i = 0; i < slice.length; i++) {
byteNumbers[i] = slice.charCodeAt(i);
}
const byteArray = new Uint8Array(byteNumbers);
byteArrays.push(byteArray);
}
const blob = new Blob(byteArrays, { type: 'image/png' });
// 创建下载链接
const url = window.URL.createObjectURL(blob);
// 创建元素并设置下载属性
const link = document.createElement('a');
link.href = url;
link.download = 'file.png';
// 模拟点击下载链接
link.click();
// 释放URL对象
window.URL.revokeObjectURL(url);
请注意,上述代码示例中的路径和文件名应根据实际情况进行调整。