gpt4 book ai didi

Angular - POST上传的文件

转载 作者:太空狗 更新时间:2023-10-29 16:46:09 25 4
gpt4 key购买 nike

我正在使用 Angular , TypeScript将文件连同 JSON 数据发送到服务器。

下面是我的代码:

import {Component, View, NgFor, FORM_DIRECTIVES, FormBuilder, ControlGroup} from 'angular2/angular2';
import {Http, Response, Headers} from 'http/http';


@Component({ selector: 'file-upload' })
@View({
directives: [FORM_DIRECTIVES],
template: `
<h3>File Upload</h3>

<div>
Select file:
<input type="file" (change)="changeListener($event)">
</div>

`
})
export class FileUploadCmp {

public file: File;
public url: string;
headers: Headers;


constructor(public http: Http) {
console.log('file upload Initialized');
//set the header as multipart
this.headers = new Headers();
this.headers.set('Content-Type', 'multipart/form-data');
this.url = 'http://localhost:8080/test';
}

//onChange file listener
changeListener($event): void {
this.postFile($event.target);
}

//send post file to server
postFile(inputValue: any): void {

var formData = new FormData();
formData.append("name", "Name");
formData.append("file", inputValue.files[0]);

this.http.post(this.url +,
formData ,
{
headers: this.headers

});
}

}

如何将 formData 转换为 String 并将其发送到服务器?我记得在AngularJS (v1) 您将使用 transformRequest

最佳答案

看看我的代码,但要注意。我使用 async/await,因为最新的 Chrome beta 可以读取任何 es6 代码,这些代码是通过 TypeScript 编译得到的。因此,您必须用 .then() 替换 asyns/await。

输入更改处理程序:

/**
* @param fileInput
*/
public psdTemplateSelectionHandler (fileInput: any){
let FileList: FileList = fileInput.target.files;

for (let i = 0, length = FileList.length; i < length; i++) {
this.psdTemplates.push(FileList.item(i));
}

this.progressBarVisibility = true;
}

提交处理程序:

public async psdTemplateUploadHandler (): Promise<any> {
let result: any;

if (!this.psdTemplates.length) {
return;
}

this.isSubmitted = true;

this.fileUploadService.getObserver()
.subscribe(progress => {
this.uploadProgress = progress;
});

try {
result = await this.fileUploadService.upload(this.uploadRoute, this.psdTemplates);
} catch (error) {
document.write(error)
}

if (!result['images']) {
return;
}

this.saveUploadedTemplatesData(result['images']);
this.redirectService.redirect(this.redirectRoute);
}

文件上传服务。该服务还在 progress$ 属性中存储了上传进度,在其他地方,您可以订阅它并每 500 毫秒获取一次新值。

import { Component } from 'angular2/core';
import { Injectable } from 'angular2/core';
import { Observable } from 'rxjs/Observable';
import 'rxjs/add/operator/share';

@Injectable()
export class FileUploadService {
/**
* @param Observable<number>
*/
private progress$: Observable<number>;

/**
* @type {number}
*/
private progress: number = 0;

private progressObserver: any;

constructor () {
this.progress$ = new Observable(observer => {
this.progressObserver = observer
});
}

/**
* @returns {Observable<number>}
*/
public getObserver (): Observable<number> {
return this.progress$;
}

/**
* Upload files through XMLHttpRequest
*
* @param url
* @param files
* @returns {Promise<T>}
*/
public upload (url: string, files: File[]): Promise<any> {
return new Promise((resolve, reject) => {
let formData: FormData = new FormData(),
xhr: XMLHttpRequest = new XMLHttpRequest();

for (let i = 0; i < files.length; i++) {
formData.append("uploads[]", files[i], files[i].name);
}

xhr.onreadystatechange = () => {
if (xhr.readyState === 4) {
if (xhr.status === 200) {
resolve(JSON.parse(xhr.response));
} else {
reject(xhr.response);
}
}
};

FileUploadService.setUploadUpdateInterval(500);

xhr.upload.onprogress = (event) => {
this.progress = Math.round(event.loaded / event.total * 100);

this.progressObserver.next(this.progress);
};

xhr.open('POST', url, true);
xhr.send(formData);
});
}

/**
* Set interval for frequency with which Observable inside Promise will share data with subscribers.
*
* @param interval
*/
private static setUploadUpdateInterval (interval: number): void {
setInterval(() => {}, interval);
}
}

关于Angular - POST上传的文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32423348/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com