我想在剃刀视图中显示resx文件中的图像:
My.cshtml:
<div>
@Model.ImageTag
</div
有了这个助手:
public static string CreateImageHtmlTag(this Bitmap bitmap)
{
ImageFormat format = null;
if (Equals(bitmap.RawFormat, ImageFormat.Png))
{
format = ImageFormat.Png;
}
else if (Equals(bitmap.RawFormat, ImageFormat.Jpeg))
{
format = ImageFormat.Jpeg;
}
else
{
throw new NotSupportedException("This image type is not supported!");
}
var stream = new MemoryStream();
bitmap.Save(stream, format);
stream.Seek(0, SeekOrigin.Begin);
var base64 = Convert.ToBase64String(stream.ToArray());
return $@"<img src='data:image/{format};base64,{base64}' />";
}
这在我的浏览器中显示:
"<img src='
rWl0YZ0XENBAMOlhPs6ng9l+ditVbSr4GA7uZf+scUzhZbBtud7Sckq9MHxQEAPhduBRPmYBzcD95U0U0hTKzzDl9Dz3Mf7a9UspdX34wEYGNuh5fs2oeftmCo0VqT0PhM9EKXVj+MB6BkKPeoSvG1AzmmXfSCliAQd4meahpBsIF4xevl5I7dEt5xpKJRU0D/KP+/YnLOkGulcjrl4E7c7021dROingD3nIK8u8A3g7VvlbqoH64NBZfB0B7YL8V1JaIci87b78UXUQb71UwzErZZJ74NwS2LaHryegnbo1chkljgTel/FPkAR1SDfsOzBvjAZiHfsVvp6gpvDREqUORVdhVIf4MV++qPLMQ2I1sLvnpdPpTZZXV1CTquVcROkDkckzDeJkmXcY9n8npXaJ1UCkPBbaX/H1xWTvwOd0lL4uujHUBTG/VeeIpCNwV7GGUnvEbiAi30Q27j4Wr0MM5vVS6nk0xUAkBhO349hG6edRNs/+tUZMFB3FiUOUuoqmGYjkejecKdnEMRzjKL2LZPNmVYPdS6lr0lQDEekmGuwP1XpBxdzZ/uEVMs3DmWXuQdeh6QYiMZzOP2cMdj38K2vMm4Xju58Oty4tMRCJ4XSWJpwPSIfZkJYZiCzNs9MgfjOfq9UKO0mgpQYi7WWi8xQdVmBabiDSDibiTDM6nFC0hYGIa6LFPufzNk+2Q4cRmrYxEGmFiXDBGKHdR6KtDESaaWKoBi9A2xmINMVEg73sX64QhbY0EKELy2f8fmQJGv0qrmWhXQnRtgYiqwqlMyD/Fn5fosJ3GLLMQ9raQERyT9wke+1a2xuISDHRYh/EsfQiEQYigiZ+jGtaKJVUEmMgEsVE+IXxJcZRCukkykAklIkW+xovRBQaC4kzEAlo4nfLB0bOoZDYSKSBCJpIM1y94+D0U7OOKbEGIrhet4aJY/hehKrETqINRHwmjvtfMsVN4g1EyjMg2KZWTFZPhYGtpGOgIB0DBekYKEjHQEE6BgrSMVAQEQP/rQTip
B4qXnRA+wcqPsANfYmKGwMB3kSeuNZzJIHyd7XKPuCiIipujGbaH1UCoRs/SMWLDmj/G56Blt1DxY2Byuu8QJNtlfGKMGngKwJo+yR5MJvNs/NoU2NWFErLIMgbB3WL3UObFg1wFhqV9uNUPSoODg6axxKwfXA1lrKiKAngnQe02fsEFH5bkDYFx51parBtlSSgvZESJQxae/Ij1+4tkd81w70PLlj+h0uG2gzG9uFpTtUST3dP8SQ8w2CoGoL28d8M2yX83RxcPqqazvdcUl6HQLtToFptm4COcjnZIAY+1ITT9xlIut+3kzQKlz+8GcsZtnKNc65mOGtxJgCNjw2/L5oA4adNJ/A1KVxtnxNdOaooivI/TJ7jyaaaFhoAAAAASUVORK5CYII=' />"
为什么不渲染图像而只插入一个字符串?
答案 0 :(得分:0)
你的base64代码是正确的,如果我解码它会打开它作为图像。也许问题在于扩展(尝试使用数据:image / png而不是Png,所以小写)。
答案 1 :(得分:0)
尝试返回MvcHtmlString
而不是string
。
public MvcHtmlString(
string value
)
在这里查看更多解释: What is an MvcHtmlString and when should I use it?
答案 2 :(得分:0)
更改您的cshtml:
<div>
@Model.ImageTag
</div>
到
<div>
@Html.Raw(@Model.ImageTag)
</div>
答案 3 :(得分:0)
默认情况下返回一个字符串在收到字符串时不转换你的html标签。 Asp.net提供标签 Html.Raw(您的字符串)以帮助转换它。