파일을 업로드하고 실제 파일로 서버에 저장하는 방법을 알고 있습니다. 성공적으로이 솔루션을 구현 했으므로 그물에 많은 예제가 있습니다.서버에 파일을 업로드하고 SQL Server 데이터베이스에 저장하는 웹 API 컨트롤러
이제 파일 업로드를 검색하고 SQL Server 데이터베이스에 저장합니다. 완전히 다른 접근 방식입니까? 나는 그물에 대한 몇 가지 예를 찾을 수 없습니다.
구체적인 구현을위한 모든 블로그/예제를 환영합니다.
감사합니다.
[HttpPost]
public Task<HttpResponseMessage> Post()
{
string RootPath = HttpContext.Current.Server.MapPath("~/" + RootFolder);
if (Request.Content.IsMimeMultipartContent())
{
var streamProvider = new CustomMultipartFormDataStreamProvider(RootPath);
var task = Request.Content.ReadAsMultipartAsync(streamProvider).ContinueWith<HttpResponseMessage>(t =>
{
if (t.IsFaulted || t.IsCanceled)
{
throw new HttpResponseException(HttpStatusCode.InternalServerError);
}
// Move the file to the right destination depending on the type (defined client side)
string type = streamProvider.FormData.GetValues("type").FirstOrDefault();
string fullname = streamProvider.FormData.GetValues("fullname").FirstOrDefault();
FileType fileType;
if (!Enum.TryParse<FileType>(type, out fileType))
{
throw new HttpResponseException(Request.CreateResponse(HttpStatusCode.NotAcceptable, "The file type is incorrect"));
}
var DestPath = RootPath + "\\" + GetFolderName(fileType);
if (!Directory.Exists(DestPath))
Directory.CreateDirectory(DestPath);
var fileInfo = streamProvider.FileData.Select(i =>
{
var info = new FileInfo(i.LocalFileName);
var fileName = fullname + info.Extension;
var srcFile = RootPath + "\\" + info.Name;
var dstFile = DestPath + "\\" + fileName;
var filesize = info.Length;
switch (fileType)
{
case FileType.DriverCertificate:
if (File.Exists(dstFile))
File.Delete(dstFile);
File.Move(srcFile, dstFile);
break;
default:
break;
}
return new FileDescription(fileName, DriverCertificatesFolder + "/" + fileName, filesize/1024);
});
return new HttpResponseMessage()
{
Content = new JsonContent(new
{
Success = true,
Data = fileInfo
})
};
;
});
return task;
}
else
{
throw new HttpResponseException(Request.CreateResponse(HttpStatusCode.NotAcceptable, "This request is not properly formatted"));
}
}
여기 내 대답을 살펴볼 수 있습니다. http : //stackoverflow.com/questions/15842496/is-it-possible-to-override-multipartformdatastreamprovider-so-that-is-doesnt-sa/15843410#15843410 ... AWS 스트림 대신 여기에서 대신 데이터베이스로 스트리밍 할 수 있습니다. –