Welcome to deBUG.to Community where you can ask questions and receive answers from Microsoft MVPs and other experts in our community.
0 like 0 dislike
2.7k views
in .Net Framework by 21 56 70
edited by

I am trying to consume by API that returns an image with base64 string format. What is the best way to insert this image into my DataBase SQL Server?

I tried in DB the dataType of the image {varbinary(MAX), and Image}, but the bytes didn't insert all, Do I have to convert the base64 string to another format before inserting it into the database?

How to insert this image into the SQL Server database? Do I need to use VARBinary or Image or something else?


1 Answer

1 like 0 dislike
by 21 56 70
edited by
 
Best answer

Which data type should I use in SQL to store Image in Base64?

Since the API returns a base64 string, you should be able to insert the image with dataType varchar(MAX) and the image will be stored without any issues.

The max size of 'varchar(MAX)' is 2GB.
image Data type for base64 in SQL Server DB

Convert Image to Base64 using C#.

And in your code, you have to convert your image field to base64 as below:

  byte[] imageArray = System.IO.File.ReadAllBytes(@"image file path");
  string base64Image= Convert.ToBase64String(imageArray);

Get an image in base64 format from SQL server to image tag in HTML using C#.

To retrieve or get an image in base64 format from the SQL server, you have to do the following:

 <img src="data:image/png;base64, YourValue">

get base64 image to image in HTML using C#

So in our case, we can use the below code to bind your image in Base64 to the <img> tag in HTML and bind the field name as below

 <img src="data:image/png;base64, <%# Eval("FieldName") %>" />

In case the image is returned as bytes and you would like to use it as base 64, you can use the below code

<img src="data:image/png;base64, <%# Convert.Base64String(byte[] Eval("FieldName")) %>" />
If you don’t ask, the answer is always NO!
...