強いタイプのビューがあります。この強い型にはbyte []で構成されるフィールドがあり、この配列には画像が含まれています。
この画像を@ Html.Image(Model.myImage)のようなもので表示することは可能ですか?
どうもありがとうございました
画像をFileContentResultとして返すコントローラーアクションメソッドを作成できます。
public FileContentResult Display(string id) {
byte[] byteArray = GetImageFromDB(id);
return new FileContentResult(byteArray, "image/jpeg");
}
次に、モデルの画像IDを使用して、ビュー内のアクションメソッドへのActionLinkを作成できます。
画像の大きさによります。小さい場合は、base-64でエンコードして、htmlに埋め込むことができます これらのいずれかのように 。
ここからの具体例 :
_<img src="" alt="British Blog Directory" width="80" height="15">
_
画像のサイズがかなり大きい場合は、代わりに、画像へのキーを介してルックアップできるルート、つまり_/images/{id}
_のようなルートを作成することをお勧めします。そのルートでは、画像のバイナリをフェッチして使用します return File(bytes, contentType)
、さらにキャッシュヘッダーを設定します(必要なセキュリティを再確認することを忘れないでください)。あなたのhtmlであなたはただ持っているでしょう
_<img src="/images/@imageId" ... />
_
(かみそりの構文を使用しますが、aspxについても同様です)。
個別ルートアプローチでは、サーバーへの追加のホップが必要ですが、クライアントでのキャッシュが可能です(インラインbase-64アプローチでは、すべてのリクエストにデータが配置されます)。
(データベースから?)バイト配列を取得し、 File メソッドを介して画像を返す新しいアクションが必要なようです..。
次に、そのアクションを指すアンカーを生成します。これにより、ページの読み込み中に画像を読み込むことができ、表示が高速化されます。
画像を提供するための単純な汎用ハンドラーを設計します。このハンドラーは、いくつかのパラメーターを指定すると、データベースから画像をロードし、それらをhttp出力ストリームに書き込むことができます。
public class UserImage : IHttpHandler
{
public bool IsReusable
{
get { return false; }
}
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "image/jpeg";
// Get the stream from the database
var image = System.Drawing.Image.FromStream(stream);
image.Save(context.Response.OutputStream, ImageFormat.Jpeg);
}
}