Now for show sample tutorial to with an example we will create a new asp.net core mvc application using c#.net. In this article I have used asp.net core 8 mvc. After creating the asp.net core 8 mvc application add a model class file and add the below code.
public class FileModel
{      
    public IFormFile File { get; set; }
    public string FilePath { get; set; }
}After adding the model class file, we will add a folder in the wwwroot folder. In this folder we will upload the file and then by passing the uploaded file path to view we will display the uploaded image preview.
Now let's add a controller class file. In this controller class file, we will add a HttpGet method of return type IActionResult. 
 [HttpGet]
public IActionResult Index()
{
    FileModel fileModel = new FileModel();
    return View(fileModel);
}  @model FileModel
@{
    ViewData["Title"] = "Home Page";
}
@using (Html.BeginForm("Index", "Home", FormMethod.Post, new { @enctype = "multipart/form-data" }))
{
    <div style="color:red">@ViewBag.Message </div>
    <div style="font-weight:bold;">Select File:</div>
    <div>
        <input type="file" class="form-control" name="file" />
    </div>
    <br />
    <div><input type="submit" value="Upload File" /></div>
     <b>FILE PREVIEW</b>
    <div style="color:brown">
        <img src="@Model.FilePath" width="200px" height="200px" />
    </div>
} In this I have added "@enctype = "multipart/form-data". This is the most important piece of the view code. If we don't add this attribute on click on submit button, we will not get the uploaded file detail at controller end. Here enctype describe the encode type of the form data when user post the data to server.
ViewBag have been used to display the message. Here input control of type file have been used, this will help user to select or browse the file. In this the most important thing ius the name of the input control. In current case is name="file". Here the name of the input control name and the model class property of type IFormFile variable name should be same. If there is any difference on that case, you will not be able to get the uploaded file detail at controller end on submit or post of the form.
 [HttpPost]
public IActionResult Index(FileModel fileModel)
{
    if (fileModel.File != null)
    {
        try
        {
            string parentPath = @"wwwroot\Demofiles\";
            string uploadfilepath =Path.Combine(Directory.GetCurrentDirectory(), parentPath, fileModel.File.FileName);
            var filestream = new FileStream(uploadfilepath, FileMode.Create);
            fileModel.File.CopyToAsync(filestream);
            string dbSaveUploadPath = string.Format("{0}{1}", @"\Demofiles\", fileModel.File.FileName);
            fileModel.FilePath = dbSaveUploadPath;
            ViewBag.Message = "File uploaded successfully.";
        }
        catch (Exception ex)
        {
            ViewBag.Message = ex.Message;
        }
    }
    else
    {
        ViewBag.Message = "Please select file to upload.";
    }
    return View(fileModel);
} Here I have used Path.Combine to prepare the upload file path as @"wwwroot\Demofiles\". After that I have taken FileStream to prepare the upload file stream instance. in file stream object i have passed the upload file path and the FileMode as Create. This will create the instance of the file on the given path. At the end CopyToAsync to copy the file to the directory. To provide the saved path for file in database. At end user view message have been stored in the ViewBag to display on page to user. Now we have done let's run the code to check the output. and now click on upload button without selecting the file you will get message to select the file.
Now let's select the file and click on button.
Here we are able to get the uploaded file detail at controller end. Here you can see thee Input file control name and the IFormFile property is same. any difference will cause trouble to get the file in controller. Now let's press F5 and check the final output.
Above showing the uploaded file and below is the output in view.






