2016-05-23 8 views
1

は、私は、ファイルアップロード以下の方法している一時フォルダに保存します。ここファイルをアップロードし、

[HttpPost] 
    public ActionResult Upload() 
    { 

     string directory = @"C:\Temp\"; 

     HttpPostedFileBase file = Request.Files["file"]; 

     if (file != null && file.ContentLength > 0) 
     { 
      var fileName = Path.GetFileName(file.FileName); 

      file.SaveAs(Path.Combine(directory, fileName)); 
     } 
     return RedirectToAction("Index"); 
    } 

とは、私のAJAX呼び出しです:

$('#uploadButton').on('click', function() 
{ 

    $.ajax({ 
     type: "POST", 
     dataType: 'json', 
     url: '@Url.Action("Upload", "Application")', 
     timeout: 2000, 
     contentType: 'application/json', 
     success: function (data) { 

      //show content 
      alert('Success!') 
     } 
    }); 
} 
) 

私は、「送信する必要がありますRequest.files ["file"] "とアップロードされたファイル。ここで

は私のコードが配置されている形式です。

<form action="/profile/upload" method="post" enctype="multipart/form-data"> 

    <div class="form-group"> 

     <label>File</label> 

     <input type="file" name="file" id="file" class="form-control" /> 
     <br /> 
     <input type="button" id="uploadButton" value="Upload" /> 
    </div> 
</form> 
+0

、サーバー側のコードは、どのような言葉を書かれていますか?タグを追加してください。 –

+0

あなたはリクエストのcontentTypeを変更して試してみることができます。あなたのコードでファイルをどのように読み込んでいるのかはわかりません。 – Nagaraj

答えて

0

はこれを試してみてください。

$('#uploadButton').on('click', function() { 
    var data = new FormData(); 
    var files = $('[type="file"]').get(0).files; 
    // Add the uploaded image content to the form data collection 
    if (files.length > 0) { 
     data.append("file", files[0]); 
    } 

    $.ajax({ 
     type: "POST", 
     url: '@Url.Action("Upload", "Application")', 
     type: 'POST', 
     data: data, 
     cache: false, 
     contentType: false, 
     processData: false, 
     success: function (data) { 
      //show content 
      alert('Success!') 
     } 
    }); 

}) 
+0

HttpPostedFileBase file = Request.Files ["file"]; nullを返しました –

+0

このリクエストを確認してください。ファイル[0] –

関連する問題