Как правильно отобразить этот байт [] как изображение, которое может появиться в браузере? - PullRequest
0 голосов
/ 24 февраля 2019

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

Ранее я использовал этокак метод расширения, который отображал следующий HTML

 <img width="250" height="250" alt="Authentication Barcode" 
  src="">

Однако тот же подход, похоже, не работает как ActionResult.Какие еще подходы я должен рассмотреть, чтобы сделать этот рендер?

    [ResponseCache(Location = ResponseCacheLocation.None, NoStore = true)]
    public IActionResult QRCode()
    { 
        // string url, string alt = "QR code", int height = 500, int width = 500, int margin = 0)
        var content = "https://example.net/go?asf";
        var width = Convert.ToInt32(250);
        var height = Convert.ToInt32(250);
        var margin = Convert.ToInt32(0);

        var qrWriter = new ZXing.BarcodeWriterPixelData
        {
            Format = ZXing.BarcodeFormat.DATA_MATRIX,
            Options = new QrCodeEncodingOptions { Height = height, Width = width, Margin = margin }
        };

        var pixelData = qrWriter.Write(content);

        // creating a bitmap from the raw pixel data; if only black and white colors are used it makes no difference
        // that the pixel data ist BGRA oriented and the bitmap is initialized with RGB
        // the System.Drawing.Bitmap class is provided by the CoreCompat.System.Drawing package
        using (var bitmap = new System.Drawing.Bitmap(pixelData.Width, pixelData.Height, System.Drawing.Imaging.PixelFormat.Format32bppRgb))
        using (var ms = new MemoryStream())
        {
            // lock the data area for fast access
            var bitmapData = bitmap.LockBits(new System.Drawing.Rectangle(0, 0, pixelData.Width, pixelData.Height),
               System.Drawing.Imaging.ImageLockMode.WriteOnly, System.Drawing.Imaging.PixelFormat.Format32bppRgb);
            try
            {
                // we assume that the row stride of the bitmap is aligned to 4 byte multiplied by the width of the image
                System.Runtime.InteropServices.Marshal.Copy(pixelData.Pixels, 0, bitmapData.Scan0,
                   pixelData.Pixels.Length);
            }
            finally
            {
                bitmap.UnlockBits(bitmapData);
            }
            // save to stream as PNG
            bitmap.Save(ms, System.Drawing.Imaging.ImageFormat.Png);
            var barcodeImageArray = new byte[ms.Length];
            ms.Read(barcodeImageArray, 0, barcodeImageArray.Length);

            string filename = "login.png";
            string contentType;
            new FileExtensionContentTypeProvider().TryGetContentType(filename, out contentType);
            var timestamp = DateTime.UtcNow;

            // Strong vs weak etag: /3082128/slabye-etags-i-last-modified#3082132
            var tag = new EntityTagHeaderValue(new Microsoft.Extensions.Primitives.StringSegment("\""+ timestamp.Ticks.ToString() + "\""), isWeak: false);

            return File(barcodeImageArray, contentType, timestamp, tag);
        }
    }

Вот след Fiddler хорошего изображения:

enter image description here

Вот вывод из «сломанного» изображения

enter image description here

Наконец, вот изменения в вышеуказанной функции, необходимые для ее рендеринга в браузереиспользование помощников Razor

   // Continue from script above where PNG is saved to stream 
            bitmap.Save(ms, System.Drawing.Imaging.ImageFormat.Png);

            output.TagName = "img";
            output.Attributes.Clear();
            output.Attributes.Add("width", width);
            output.Attributes.Add("height", height);
            output.Attributes.Add("alt", alt);
            output.Attributes.Add("src",
               String.Format("data:image/png;base64,{0}", Convert.ToBase64String(ms.ToArray())));
        }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...