我正在使用 Angular 2 和 HTML 文件上传控件进行文件上传操作。我上传文件的代码如下 -
saveDocument(value: any) {
let apiEndPoint: any = 'http://localhost:58736/LandingPage/addUpdateDocument';
let fi = this.FileInput.nativeElement;
if (fi.files && fi.files[0]) {
let fileToUpload = fi.files[0];
let formData: FormData = new FormData();
formData.append('newDocument', fileToUpload, value);
let headers = new Headers();
headers.append('Accept', 'application/json');
let options = new RequestOptions({ headers: headers });
this._http.post(`${apiEndPoint}`, formData , options).map(res => res.json()).catch(error => Observable.throw(error)).subscribe(
data => console.log('success'),
error => console.log(error))
}
}
Run Code Online (Sandbox Code Playgroud)
我有一个 ASP.Net MVC 服务器端方法,如下 --
[System.Web.Http.HttpPost]
public string addUpdateDocument(HttpPostedFileBase newDocument)
{
string responseMessage = string.Empty;
try
{
if (newDocument.ContentLength > 0)
{
string _FileName = Path.GetFileName(newDocument.FileName);
string _path = Path.Combine(Server.MapPath("~/upload"), _FileName);
newDocument.SaveAs(_path);
}
responseMessage = "Upload Successfull !!";
}
catch(Exception ex)
{
responseMessage = "Upload Successfull !!";
}
return responseMessage;
}
}
Run Code Online (Sandbox Code Playgroud)
只要我只上传文件,这就可以正常工作。但除了文件之外,我想发送更多信息。我尝试按如下方式实现该功能——
this._http.post(`${apiEndPoint}`,{'newDocument':formData,'documentMetaData':value} , options).map(res => res.json()).catch(error => Observable.throw(error)).subscribe(
data => console.log('success'),
error => console.log(error))
Run Code Online (Sandbox Code Playgroud)
然后我修改了服务器端方法如下 -
[System.Web.Http.HttpPost]
public string addUpdateDocument(HttpPostedFileBase newDocument, BlankFormsModels documentMetaData)
Run Code Online (Sandbox Code Playgroud)
其中 BlankFormsModels 只是一个类。当我这样做时,服务器端收到元数据,但未收到文件。它为空。请建议如何在同一请求中 POST 表单数据和 JSON 数据。
小智 -3
您可以像这样发送数据:
var obj = {
formData : formData,
otherInfo : otherInfo
}
Run Code Online (Sandbox Code Playgroud)
在服务器端,上传文件时,使用 的密钥而formData不是obj整个对象。之后发布另一个数据。使用 Promise 来实现正确的同步。
| 归档时间: |
|
| 查看次数: |
4744 次 |
| 最近记录: |