Skip to content

Instantly share code, notes, and snippets.

@vbfox
Created July 21, 2010 15:35
Show Gist options
  • Save vbfox/484643 to your computer and use it in GitHub Desktop.
Save vbfox/484643 to your computer and use it in GitHub Desktop.
Convert from a DataUrl to an Image in C#
using System;
using System.Drawing;
using System.IO;
using System.Text.RegularExpressions;
using System.Windows.Forms;
class Program
{
static string data = @"";
static void Main(string[] args)
{
var base64Data = Regex.Match(data, @"data:image/(?<type>.+?),(?<data>.+)").Groups["data"].Value;
var binData = Convert.FromBase64String(base64Data);
using (var stream = new MemoryStream(binData))
{
var pictureBox = new PictureBox {
Image = new Bitmap(stream),
};
var form = new Form { AutoSize = true, AutoSizeMode = AutoSizeMode.GrowAndShrink };
form.Controls.Add(pictureBox);
Application.Run(form);
}
}
}
@Earl-Brown
Copy link

A slightly more generic expression is
@"data:(?.+?);(?.+?),(?.+)"

This allows for files of any type, and also gives you the encoding used (base64 might not be the only option in the future).

@NikitaEgorov
Copy link

Thanks!

@xltuo
Copy link

xltuo commented Feb 16, 2017

Thanks!

Copy link

ghost commented May 8, 2017

An exception of type 'System.FormatException' occurred in mscorlib.dll but was not handled in user code

Additional information: The input is not a valid Base-64 string as it contains a non-base 64 character, more than two padding characters, or an illegal character among the padding characters.

I get this error in case of MVC application

@wtfuii
Copy link

wtfuii commented Nov 30, 2017

Use this regex to get the exact file type and base64 string:
@"data:(?<type>.+?);base64,(?<data>.+)"

@magicleon94
Copy link

Amazing, just what I needed. Thank you!

@random82
Copy link

random82 commented Apr 18, 2018

Looks good, one thing I've done differently is extracting whole content type, like this:

var match = Regex.Match(statementRequest.Content, @"data:(?<type>.+?);base64,(?<data>.+)");
var base64Data = match.Groups["data"].Value;
var contentType = match.Groups["type"].Value;
var binData = Convert.FromBase64String(base64Data);

@victorjonsson
Copy link

I’ve published a package that you can use if you would like to manage data url’s in a more OOP-friendly way https://www.nuget.org/packages/DataUtils.DataUrl/#

@leizhtw
Copy link

leizhtw commented Aug 25, 2020

Thanks.

@rleituz
Copy link

rleituz commented Apr 5, 2021

excelente!! muchas gracias

@sgf
Copy link

sgf commented Dec 5, 2022

I’ve published a package that you can use if you would like to manage data url’s in a more OOP-friendly way https://www.nuget.org/packages/DataUtils.DataUrl/#

too complex

@victorjonsson
Copy link

@sgf It really shouldn't be. Going from image on disk to base64 string or from base64 string to whatever is literally only two lines of code. Could you please elaborate on what feels too complex?

@sgf
Copy link

sgf commented Dec 5, 2022

@sgf It really shouldn't be. Going from image on disk to base64 string or from base64 string to whatever is literally only two lines of code. Could you please elaborate on what feels too complex?

In fact, what I want to say is that the implementation is too complicated.
It should be only one line of code when used.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment