ASP.NET Core Image Upload and Resize
Asked Answered
E

3

11

How do you get the file stream of an uploaded image (IFormFile) and resize it?

public ActionResult Upload(IFormFile file)
{
    using (var reader = new StreamReader(file.OpenReadStream()))
    {
        var fileContent = reader.ReadToEnd();
        var parsedContentDisposition = ContentDispositionHeaderValue.Parse(file.ContentDisposition);

        //scale image here?
    }
}
Educated answered 27/1, 2016 at 2:41 Comment(0)
E
13

You can use IFormFile.OpenReadStream() to get the stream, and then just insert the stream into an Image. For this instance I scaled it to 1024x768.

Image image = Image.FromStream(file.OpenReadStream(), true, true);
var newImage = new Bitmap(1024, 768);
using (var g = Graphics.FromImage(newImage))
{
    g.DrawImage(image , 0, 0, 1024, 768); 
}

You can then use newImage to save or do whatever you want with.

Educated answered 27/1, 2016 at 2:41 Comment(4)
This will work if it targets the full framework and not just the core. I could be wrong but I don't think there's a way to manipulate images in the core yet. hanselman.com/blog/… (There are enough things missing for me that I targeted 4.6 libraries for reasons like this).Palanquin
asp.net-core and asp.net 5 are temporary synonyms on stackoverflow for the time being; However, I will update the tag to include asp.net for clarity. I was talking about the full framework (4.6 and core) fyi. Thanks!Educated
You should take a look at this project (github.com/JimBobSquarePants/ImageProcessor) which is currently being updates for ASP.NET Core support. It's got pretty good traction and I believe it to be the only solution to the problem right now. We use it across multiple .NET sites.Brownlee
It's nothing new: msdn.microsoft.com/en-us/library/…Semiyearly
A
6

Install from nuget : Install-Package SixLabors.ImageSharp

[HttpPost]
public IActionResult Upload(IFormFile file)
{
    //Better use extension method
    string fileName;
    string customRoot = "wwwroot\\Upload\\";
    Directory.CreateDirectory(customRoot);
    var path = Path.Combine(Directory.GetCurrentDirectory(), customRoot,fileName);
    using var image = Image.Load(file.OpenReadStream());
    //100: height
    //100: width
    image.Mutate(x => x.Resize(100, 100));
    image.Save(path); 
    return Ok();
}

for more information : https://blog.elmah.io/upload-and-resize-an-image-with-asp-net-core-and-imagesharp/

Astri answered 6/1, 2021 at 15:31 Comment(0)
K
0

Very helpful. Thank you so much. This aspect saved me from out of memory exception.I want to make a contribution, if you are using IFormFile interface, then "file" refers to your IFormFile in the code.

This is IFormFile property of my Entity

[NotMapped]
public IFormFile MyImage1 { set; get; }

And this is how i use it

Image image = Image.FromStream(model.MyImage1.OpenReadStream(), true, true);
Keilakeily answered 25/9, 2019 at 11:57 Comment(1)
Welcome to SO!!Mittel

© 2022 - 2024 — McMap. All rights reserved.