【发布时间】:2014-09-15 23:02:39
【问题描述】:
我有一个问题,当我调用我的 API 来获取图像时,我得到的是二进制图像。我想是的……
ImageConverter imageConverter = new ImageConverter();
byte[] resourceByteArray = (byte[])imageConverter.ConvertTo(_Obj.GetImage(), typeof(byte[]));
MemoryStream dataStream = new MemoryStream(resourceByteArray);
response = new HttpResponseMessage(HttpStatusCode.OK);
response.Content = new StreamContent(dataStream);
response.Content.Headers.ContentType = new MediaTypeHeaderValue("image/" + parameters.ImageFormat);
前端代码。
$("#formoid").submit(function (event) {
/* stop form from submitting normally */
event.preventDefault();
/* get some values from elements on the page: */
var $form = $(this),
url = $form.attr('action');
/* Send the data using post */
var posting = $(this).serialize();
$.ajax({
type: "POST",
url: url,
data: posting
}).done(function (data) {
$('#output').html('<img src="data:image/PNG;base64' + data + '" />');
});
});
最终结果是:
<img src="data:image/PNG;base64�PNG
���
IHDR�����@��������sRGB�������gAMA�����a��� pHYs�������o�d����IDATx^���W��}�}��s�{�s���g�t��epww��N ��I � �@�@�]�'F���o���ݫv�������<�g�k������Uk��k���P��+��eˢT�R��`��%J�p�¾��\��`pGƪ\k0\i��!%0���`�
【问题讨论】:
-
看起来像来自 Ajax 响应的数据的编码问题。尝试解析 json 并尝试将其更改为合适的格式,如 Base64 等。您也可以从服务器端处理。
标签: jquery ajax asp.net-web-api