我将尝试在我的MEAN应用中实现文件上传。我的后端(Node和Express)和前端(Angular)是分别部署的。我需要通过Angular将文件上传到亚马逊s3,成功上传后获取目标地址,然后将文件目标保存到变量中。
有没有简单的方法来实现这个呢?假设我有一个像这样的表单。
然后这段代码将会被放在我的组件上(仅用于测试我是否可以获取文件)。
有没有简单的方法来实现这个呢?假设我有一个像这样的表单。
<form [formGroup]="form" (ngSubmit)="onSubmit()">
<input type="file" id="myImage" (change)="onFileChange($event)" #fileInput>
<hr>
<div class="text-right">
<button type="submit" class="btn btn-primary">Actualizar perfil</button>
</div><br>
</form>
然后这段代码将会被放在我的组件上(仅用于测试我是否可以获取文件)。
@ViewChild('fileInput') fileInput: ElementRef;
createForm() {
this.form = this.formBuilder.group({
'myImage': null
});
}
onFileChange(event) {
let reader = new FileReader();
if(event.target.files && event.target.files.length > 0) {
let file = event.target.files[0];
reader.readAsDataURL(file);
reader.onload = () => {
this.form.get('myImage').setValue({
filename: file.name,
filetype: file.type,
value: reader.result.split(',')[1]
})
};
}
}
onSubmit() {
const formModel = this.form.value;
this.loading = true;
setTimeout(() => {
console.log(formModel);
alert('Finished uploading');
this.loading = false;
}, 1000);
}
我该如何将表单中的文件发送到Amazon S3?然后获取Amazon S3中的文件目标地址,以便稍后保存到我的数据库中进行提取。我也不确定是否应该在后端或前端创建Amazon S3配置,我现在很困惑。