我有一个页面,在那里我们将.csv文件上传到数据库。我们调用一个webapi方法,该方法读取文件并将数据插入表中。当我们上传文件时,弹出窗口会显示一个取消按钮。如果用户按下取消按钮,我想做的是取消文件上传过程。为此,我创建了一个promise,并在单击取消按钮时调用它,它正在取消http请求,但我面临的问题是,已经导入数据库的数据仍然存在。例如,如果我们在文件中有100行,而当我按下取消按钮时,已经有50行被插入到数据库中,那么这些行将保持不变。我需要一些帮助来弄清楚如何恢复已经插入表中的数据。这是我正在使用的代码:
var requestPromise = $http({
method: 'POST',
url: mpCONFIG.apiServiceBaseUri + 'import/fileImport',
data: formData,
transformRequest: angular.identity,
timeout: canceller.promise,
headers: {
'Content-Type': undefined
}
});
return requestPromise.success(function(resp, status) {
file.progress = undefined;
if (typeof resp != 'undefined' && resp != null && resp.length > 0) {
$rootScope.caseFileId = resp[0];
listImportRows(1, resp[0]);
}
})
.error(function(data, status) {
$scope.waitOnLoadingFile(false);
file.progress = undefined;
});
};
$rootScope.cancelLoadingFile = function() {
canceller.resolve("User Cancelled");
$scope.waitOnLoadingFile(false);
$window.location.reload();
}
编辑:我发现它根本没有取消请求。在中途停车的最初印象是不正确的,这是由于其他问题造成的。因此,当我按下取消按钮时,调用了cancellLoadinfFile,但看起来像是canceller.resolve并没有取消请求。下面是web api方法。
[Route("fileImport")]
[HttpPost]
public System.Threading.Tasks.Task<IHttpActionResult> UploadImage()
{
try
{
IEnumerable<Models.mlsp.Firm> firms = (from cs in User.Firms(db)
select cs);
HttpRequestMessage request = this.Request;
if (!request.Content.IsMimeMultipartContent())
{
throw new HttpResponseException(new HttpResponseMessage(HttpStatusCode.UnsupportedMediaType));
}
MultipartFormDataStreamProvider provider = new MultipartFormDataStreamProvider(Properties.Settings.Default.UploadTempFolder);
string user = RequestContext.Principal.Identity.Name;
System.Threading.Tasks.Task<IHttpActionResult> task = request.Content.ReadAsMultipartAsync(provider).
ContinueWith<IHttpActionResult>(o =>
{
System.Net.HttpStatusCode resultStatus = HttpStatusCode.OK;
int?[] result = new int?[provider.FileData.Count];
try
{
for (int i = 0; i < provider.FileData.Count; i++)
{
result[i] = Logic.mlsp.Case.LoadFromFile(User, db, provider.FileData[i].LocalFileName, firms);
}
return ResponseMessage(new HttpResponseMessage()
{
StatusCode = resultStatus,
Content = new StringContent(Newtonsoft.Json.JsonConvert.SerializeObject(result))
});
}
catch (Exception ex)
{
Helpers.LogHelper.LogError(ex);
throw;
}
}
);
return task;
}
catch (Exception ex)
{
Helpers.LogHelper.LogError(ex);
throw;
}
}
根据此链接,http://www.davepaquette.com/archive/2015/07/19/cancelling-long-running-queries-in-asp-net-mvc-and-web-api.aspx,您可以将CancellationToken参数添加到控制器方法中。当客户端取消请求时,令牌也将被取消。您需要将此令牌传递给任务,或者根据需要监视IsCancellationRequested属性。