Как преобразовать байтовый массив в изображение? - PullRequest
18 голосов
/ 30 декабря 2010

Используя Javascript, я делаю AJAX-вызов службе WCF, и она возвращает байтовый массив.Как я могу преобразовать это в изображение и отобразить его на веб-странице?

Ответы [ 6 ]

18 голосов
/ 08 марта 2013

Я понимаю, что это старая ветка, но мне удалось сделать это через AJAX-вызов веб-службы, и я решил поделиться ...

  • У меня уже есть изображение на моей странице:

     <img id="ItemPreview" src="" />
    
  • AJAX:

    $.ajax({
            type: 'POST',
            contentType: 'application/json; charset=utf-8',
            dataType: 'json',
            timeout: 10000,
            url: 'Common.asmx/GetItemPreview',
            data: '{"id":"' + document.getElementById("AwardDropDown").value + '"}',
            success: function (data) {
                if (data.d != null) {
                    var results = jQuery.parseJSON(data.d);
                    for (var key in results) {
                        //the results is a base64 string.  convert it to an image and assign as 'src'
                        document.getElementById("ItemPreview").src = "data:image/png;base64," + results[key];
                    }
                }
            }
        });
    

Мой код «GetItemPreview» запрашивает сервер SQL, на котором у меня есть изображение, хранящееся в виде строки base64, и возвращает это поле в виде «результатов»:

     string itemPreview = DB.ExecuteScalar(String.Format("SELECT [avatarImage] FROM [avatar_item_template] WHERE [id] = {0}", DB.Sanitize(id)));
     results.Add("Success", itemPreview);
     return json.Serialize(results);

Магия в вызове AJAX на этой линии:

     document.getElementById("ItemPreview").src = "data:image/png;base64," + results[key];

Наслаждайтесь!

4 голосов
/ 13 февраля 2015

Вот источник JavaScript для декодирования байтов изображений PNG, JPEG и GIF с использованием схемы URI данных:

Images.decodeArrayBuffer = function(buffer, onLoad) {
    var mime;
    var a = new Uint8Array(buffer);
    var nb = a.length;
    if (nb < 4)
        return null;
    var b0 = a[0];
    var b1 = a[1];
    var b2 = a[2];
    var b3 = a[3];
    if (b0 == 0x89 && b1 == 0x50 && b2 == 0x4E && b3 == 0x47)
        mime = 'image/png';
    else if (b0 == 0xff && b1 == 0xd8)
        mime = 'image/jpeg';
    else if (b0 == 0x47 && b1 == 0x49 && b2 == 0x46)
        mime = 'image/gif';
    else
        return null;
    var binary = "";
    for (var i = 0; i < nb; i++)
        binary += String.fromCharCode(a[i]);
    var base64 = window.btoa(binary);
    var image = new Image();
    image.onload = onLoad;
    image.src = 'data:' + mime + ';base64,' + base64;
    return image;
}
4 голосов
/ 30 декабря 2010

Вместо вызова службы с помощью AJAX используйте Javascript для создания элемента изображения и указания его непосредственно на службу ...

var img = document.createElement("IMG");
img.src = "http://url/to/service";
img.alt = "ALT TEXT";
document.body.appendChild(img);

Просто убедитесь, что сервис правильно устанавливает тип контента.

1 голос
/ 01 мая 2014

Просто отправьте его обратно как Base64, а затем просто:

var sig = new Image;
sig.src = 'data:image/png;base64,' + $('#Signature').val();

В моем случае я использую Hidden Input с Id из Signature для хранения этих Base64 данных

1 голос
/ 30 декабря 2010

Возможно, вы захотите создать data-uri из ваших данных и поместить его в атрибут src элемента img

http://en.wikipedia.org/wiki/Data_URI_scheme

0 голосов
/ 20 декабря 2016

Используя jQuery в качестве примера:

var myImage = $('< img src="data:image/jpg; base64," + bytesarray + "/>"');
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...