How to to Return an Image with Web API Get Method

How to to return an image with Web API Get method

If I understand correctly then you are asking specific to asp.net core. In ASP.net core HttpResponseMessage is not a way to return result the way we used to do in ASP.net web api 2.

In asp.net core ( WEB API ) simply look like this.

[HttpGet]
public IActionResult Get()
{
Byte[] b = System.IO.File.ReadAllBytes(@"E:\\Test.jpg"); // You can use your own method over here.
return File(b, "image/jpeg");
}

Note: As you mention that in Fiddler Imageview you see message like this "his response is encoded, but does not claim to be an image." because ASP.net core consider HttpResponseMessage as simple class and convert into json or xml.

Return Image as url from .net 5 web api

what you can do is to convert base64 to binary stream then save it image folder inside the same application then return the URL as a string and in this case, the URL will be accessible.

the controller code will be as follow

using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Mvc;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Net.Http;
using System.Threading.Tasks;

namespace MyNameSpace
{
public class TestController : Controller
{
private readonly IWebHostEnvironment _webHostEnvironment;
public TestController(IWebHostEnvironment webHostEnvironment)
{
_webHostEnvironment = webHostEnvironment;
}
public IActionResult ImageLink()
{
byte[] file_bytes = Convert.FromBase64String("base 64 string");
string webRootPath = _webHostEnvironment.WebRootPath;
string imagePath = Path.Combine(webRootPath, "image/myimage.png");
System.IO.File.WriteAllBytes(imagePath, file_bytes);
return Ok("http://localhost:6548/image/myimage.png");
}

}
}

Returning an image using Web API

If you want to return file do not return byte[] from action because it gets base64 encoded. You can decode base64 string on client or better would be using File method in action

[HttpGet("{id}")]
public ActionResult Get(Guid id)
{
var files = Directory.GetFiles(@"Pictures\");
foreach (var file in files)
{
if (file.Contains(id.ToString()))
{
return File(System.IO.File.ReadAllBytes(file), "image/jpeg");
}
}
return null;
}

Is there a recommended way to return an image using ASP.NET Web API

You shouldn't return a System.Drawing.Image, unless you also add a formatter which knows how to convert that into the appropriate bytes doesn't serialize itself as the image bytes as you'd expect.

One possible solution is to return an HttpResponseMessage with the image stored in its content (as shown below). Remember that if you want the URL you showed in the question, you'd need a route that maps the {imageName}, {width} and {height} parameters.

public HttpResponseMessage Get(string imageName, int width, int height)
{
Image img = GetImage(imageName, width, height);
using(MemoryStream ms = new MemoryStream())
{
img.Save(ms, System.Drawing.Imaging.ImageFormat.Png);

HttpResponseMessage result = new HttpResponseMessage(HttpStatusCode.OK);
result.Content = new ByteArrayContent(ms.ToArray());
result.Content.Headers.ContentType = new MediaTypeHeaderValue("image/png");

return result;
}
}

But again, if you are doing this in many places, going the formatter route may be the "recommended" way. As almost everything in programming, the answer will depend on your scenario.

Return jpeg image from Asp.Net Core WebAPI

Clean solution use FilestreamResult !!

[HttpGet]
public IActionResult Get()
{
var image = System.IO.File.OpenRead("C:\\test\\random_image.jpeg");
return File(image, "image/jpeg");
}

Explanation:

In ASP.NET Core you have to use the built-in File() method inside the Controller. This will allow you to manually set the content type.

Don't create and return HttpResponseMessage, like you were used to using in ASP.NET Web API 2. It doesn't do anything, not even throwing errors!!

How to return an image (not the url) in binary via a REST API .net

If you do not have a constant public url to the image, you need to encode it to base64 and embed it as inline image.

If you can access the url inside your POCO from your Web API backend, then you can retrieve and convert the image with the following code:

        private static HttpClient _httpClient = new HttpClient();

public async Task<string> GetInlineImageSrcAsync(string url)
{
var bytes = await _httpClient.GetByteArrayAsync(url);
var base64 = Convert.ToBase64String(bytes);
var mimeType = "image/png";
// If mime types differ, try this
// var mimeType = $"image/{ParseExtensionFromUrl(url)}"
var inlineImageSrc = $"data:{mimeType};base64,{base64}";
return inlineImageSrc;
}

public string ParseExtensionFromUrl(string url)
{
return url.Substring(url.LastIndexOf(".") + 1);
}

Note that HttpClient should be static to enable it to reuse connections. This is recommended by Microsoft and boosts performance.
More on this:

https://medium.com/@nuno.caneco/c-httpclient-should-not-be-disposed-or-should-it-45d2a8f568bc

https://aspnetmonsters.com/2016/08/2016-08-27-httpclientwrong/

EDIT:
This is the HTML to actually embed the image:

<img src="<THE STRING YOU RETURNED>" />

<!-- For Example: -->
<img src="">

Returning Images from WebApi

The solution is to use media formatters, so that when the Web API is queried with a particular type, you'll then receive the actual binary stream of the particular type.

http://www.asp.net/web-api/overview/formats-and-model-binding/media-formatters

This is the standard RESTful pattern; you have the same URL, but when you want a JSON record for the data, you accept-type:application/json, but you change your MIME request type to image/png or something similar when you want that media type.

More can be found here:
How to provide custom mediatype formats for OData Api

Odata also implicitly supports it here: https://msdn.microsoft.com/en-us/library/system.web.http.odata.formatter.odatamediatypeformatter(v=vs.118).aspx



Related Topics



Leave a reply



Submit