我目前正在尝试以 BLOB 的形式查看存储在数据库中的图像,为此我创建了一个 FileContentResult 类型的控制器操作,如下所示:
public FileContentResult ImageFile(string imageId)
{
var client = new WcfTestClient();
DataTable table = client.GetImageData(imageId);
var image = ConvertToBytes(table);
byte[] bytes;
bytes = image[0].Values.ElementAt(0);
return File(bytes, @"image/png");
}
它从数据库中获取正确的图像数据,并且 ConvertToBytes() 也可以正常工作,但由于某种原因,在将图像返回到视图后,它会跳回顶部并再次运行。
我正在使用 Ajax 从我的视图中调用该方法,如下所示:
$.ajax({
url: "/Home/ImageFile",
type: "GET",
data: { "imageId": imageId },
success: function (data) {
var image = document.createElement('img');
image.src = "/Home/ImageFile?id=" + imageId;
image.width = 100;
image.height = 100;
div.appendChild(image);
}
});
有谁知道什么可能导致我的问题?
更新
好的,所以现在在被告知是 Ajax 搞砸了之后,我尝试向我的 Controller Action 发送一个参数,如下所示:
var images = JSON.parse(window.localStorage.getItem("JsonImages"));
var div = document.getElementById('imgOutput');
for (var i = 0; i < images.length; i++) {
var imageId = images[i].pi_Id;
var imgId = JSON.parse('{"imageId":' + imageId + '}');
var img = document.createElement('img');
img.src = "/Home/ImageFile?id=" + imgId;
img.width = 100;
img.height = 100;
div.appendChild(img);
}
可悲的是,这不是很好。那么,有没有办法将参数发送到 ImageFile() 而不让它运行两次?我在这里错过了一些基本的东西吗?
更新 2
最后我让它工作了!这是它现在的样子:
var images = JSON.parse(window.localStorage.getItem("JsonImages"));
var div = document.getElementById('imgOutput');
var createImage = function (src) {
var img = document.createElement('img');
img.src = src;
img.height = 100;
img.width = 100;
return img;
}
for (var i = 0; i < images.length; i++) {
var imageId = images[i].pi_Id;
var imageSrc = "/Home/ImageFile?imageId=" + imageId;
div.appendChild(createImage(imageSrc));
}
我只需要将源的参数从 id 更改为 imageId (duh)。谢谢你的帮助!