0

Gerade erst mit ASP.Net 4.5 gestartet und meine API gibt immer Internal Server Error zurück. Interner Server Fehler 500 bei async upload asp mvc 5

hochladen API

public class UploadController : ApiController 
{ 
    public async Task<HttpResponseMessage> PostFile() 
    { 
     if (!Request.Content.IsMimeMultipartContent()) 
     { 
      throw new HttpResponseException(HttpStatusCode.UnsupportedMediaType); 
     } 

     string root = HttpContext.Current.Server.MapPath("~/App_Data/uploads/"); 
     var provider = new CustomMultipartFormDataStreamProvider(root); 

     try 
     { 
      await Request.Content.ReadAsMultipartAsync(provider); 

      return Request.CreateResponse(HttpStatusCode.OK); 
     } 
     catch (System.Exception e) 
     { 
      return Request.CreateErrorResponse(HttpStatusCode.InternalServerError, e); 
     } 
    } 

}

mein Controller

var message = new HttpRequestMessage(); 
    var content = new MultipartFormDataContent(); 
    message.Method = HttpMethod.Post; 
    message.Content = content; 
    message.RequestUri = new Uri("http://localhost:12345/api/upload/"); 

    var client = new HttpClient(); 
    client.SendAsync(message).ContinueWith(task => 
    { 
      var result = task.Result.ReasonPhrase; 
      if (task.Result.IsSuccessStatusCode) 
      { 
        //do something 
      } 
    }); 

Die Dateien werden in dem Verzeichnis gespeichert (/ App_Data/uploads /), aber warum ist der Status Code immer 500?

Bitte erleuchten Sie mich. Dank

+0

[hier] (http://stackoverflow.com/questions/5193842/file-upload-asp-net-mvc-3-0) ist Datei Beispiel hochladen Kannst du mehr erzählen, wenn du diesen Fehler bekommst? –

+0

Der Link ist ein Beispiel für synchronen Upload. Meine Implementierung ist asynchron. – Awoi

+0

Einen Moment werde ich Async-Beispiel veröffentlichen. –

Antwort

0

Hier ist ein Teil der Arbeits Controller:

[HttpPost] 
    [ValidateAntiForgeryToken] 
    public async Task<ActionResult> Create(Product product, HttpPostedFileBase file) 
    { 
     if (!ModelState.IsValid) 
      return PartialView("Create", product); 
     if (file != null) 
     { 

      var fileName = Path.GetFileName(file.FileName); 
      var guid = Guid.NewGuid().ToString(); 
      var path = Path.Combine(Server.MapPath("~/Content/Uploads/ProductImages"), guid + fileName); 
      file.SaveAs(path); 
      string fl = path.Substring(path.LastIndexOf("\\")); 
      string[] split = fl.Split('\\'); 
      string newpath = split[1]; 
      string imagepath = "Content/Uploads/ProductImages/" + newpath; 
      using (MemoryStream ms = new MemoryStream()) 
      { 
       file.InputStream.CopyTo(ms); 
       byte[] array = ms.GetBuffer(); 
      } 
      var nId = Guid.NewGuid().ToString(); 
      // Save record to database 
      product.Id = nId; 
      product.State = 1; 
      product.ImagePath = imagepath; 
      product.CreatedAt = DateTime.Now; 
      db.Products.Add(product); 
      await db.SaveChangesAsync(); 
      TempData["message"] = "ProductCreated"; 

      //return RedirectToAction("Index", product); 
     } 
     // after successfully uploading redirect the user 
     return Json(new { success = true }); 
    } 
+0

HINWEIS: Sie haben Änderungsberechtigungen für Ihren Upload-Ordner: IIS_IUSRS –

+1

Ich glaube nicht, dass das Problem mit dem asynchronen Teil der Implementierung ist. Es speichert erfolgreich die Dateien auf dem Server, aber es tritt immer in den catch-Block ein. Ich weiß nicht warum. – Awoi

+0

Verzeihen Sie mir, wirklich weiß nicht warum, wie ich ree Methode verwendet wird, warum es so richtig interessant zu fangen geht. –