File upload with ASP.Net Core 2.0 Web API and React.js

后端 未结 4 527
忘了有多久
忘了有多久 2021-02-03 13:30

I\'m new to both react.js and ASP.Net core 2.0. And now writing a project using ASP.Net core 2.0 as back end API and react.js as application interface (front end). I\'d like to

相关标签:
4条回答
  • 2021-02-03 13:38

    In my case i simply missed to add multipart/form-data in my form.

    If your controller is accepting uploaded files using IFormFile but you find that the value is always null, confirm that your HTML form is specifying an enctype value of multipart/form-data. If this attribute isn't set on the element, the file upload won't occur and any bound IFormFile arguments will be null.

    Example:-

    <form method="post" enctype="multipart/form-data" asp-controller="UploadFiles" asp-action="Index">
            <div class="form-group">
                <div class="col-md-10">
                    <p>Upload one or more files using this form:</p>
                    <input type="file" name="files" multiple />
                </div>
            </div>
            <div class="form-group">
                <div class="col-md-10">
                    <input type="submit" value="Upload" />
                </div>
            </div>
        </form>
    

    Remove the multiple attribute on this input element to allow just a single file to be uploaded.

    0 讨论(0)
  • 2021-02-03 13:51
    [Route("api/[controller]")]
    [ApiController]
    public class UploaderController : ControllerBase
    {
        [HttpPost]
        public dynamic UploadJustFile(IFormCollection form)
        {
            try
            {
                foreach (var file in form.Files)
                {
                    string path = Path.Combine(@"C:\uploadFiles");
                    using (var fs = new FileStream(Path.Combine(path, file.FileName), FileMode.Create))
                    {
                        file.CopyToAsync(fs);
                    }
                    UploadFile(file);
                }
    
                return new { Success = true };
            }
            catch (Exception ex)
            {
                return new { Success = false, ex.Message };
            }
        }
    

    and in UI use this

    uploadJustFile(e) {
     e.preventDefault();
     let state = this.state;
    
    this.setState({
      ...state,
      justFileServiceResponse: 'Please wait'
    });
    
    if (!state.hasOwnProperty('files')) {
      this.setState({
        ...state,
        justFileServiceResponse: 'First select a file!'
      });
      return;
    }
    
    let form = new FormData();
    
    for (var index = 0; index < state.files.length; index++) {
      var element = state.files[index];
      form.append('file', element);
    }
    debugger;
    axios.post('/api/uploader', form)
      .then((result) => {
        let message = "Success!"
        if (!result.data.success) {
          message = result.data.message;
        }
        this.setState({
          ...state,
          justFileServiceResponse: message
        });
      })
      .catch((ex) => {
        console.error(ex);
      });
     }
    
    0 讨论(0)
  • 2021-02-03 13:56

    This answer is true but I have problem with saving an image in my API so I change the method as you see and then work nice. You should set the parameter as [FromForm] in your API method

    public async Task<IActionResult> Upload([FromForm]FileUploadViewModel model){...}
    
    0 讨论(0)
  • 2021-02-03 14:05

    I have done the job as follow:

    at .Net core 2.0 web api

    using Microsoft.AspNetCore.Http;

    I created a model class

    namespace Marter_MRM.Models
    {
        public class FileUploadViewModel
        {
            public IFormFile File { get; set; }
            public string source { get; set; }
            public long Size { get; set; }
            public int Width { get; set; }
            public int Height { get; set; }
            public string Extension { get; set; }
        }
    }
    

    And then I created a controller class and wrote the function as follow.

    [HttpPost]
    [Route("upload")]
    public async Task<IActionResult> Upload(FileUploadViewModel model) {
          var file = model.File;
    
          if (file.Length > 0) {
               string path = Path.Combine(_env.WebRootPath, "uploadFiles");
               using (var fs = new FileStream(Path.Combine(path, file.FileName), FileMode.Create))
               {
                    await file.CopyToAsync(fs);
               }
    
               model.source = $"/uploadFiles{file.FileName}";
               model.Extension = Path.GetExtension(file.FileName).Substring(1);
          }
        return BadRequest();
    }
    

    And write api call function in react as follow:

    handleUploadClick(event){
        event.preventDefault();
        var self = this;
        var apiBaseUrl =  axios.defaults.baseURL + "user/upload";
        if(this.state.filesToBeSent.length>0){
            var filesArray = this.state.filesToBeSent;
            let f = new FormData();
            for(var i in filesArray){
            //console.log("files",filesArray[i][0]);
                 f = new FormData();
                 f.append("File",filesArray[i][0] )
                 axios.post(apiBaseUrl, f, {
                        headers: {'Content-Type': 'multipart/form-data'}
                 });
            }
            alert("File upload completed");
        }
        else{
            alert("Please select files first");
        }
    }
    

    It works perfect. Thanks!

    0 讨论(0)
提交回复
热议问题