Я использую 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 хорошего изображения:
Вот вывод из «сломанного» изображения
Наконец, вот изменения в вышеуказанной функции, необходимые для ее рендеринга в браузереиспользование помощников 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())));
}