отображение двоичного потока, полученного из базы данных как "изображение" внутри html в виде тега
Я пытаюсь отобразить изображение, которое извлекается из базы данных в виде двоичного потока, на веб-форму. Можешь пролить свет на это?
Я работаю над проектом, где у пользователей есть профили, и у каждого пользователя есть собственное изображение профиля, отображаемое на домашней странице. Это изображение взято из базы данных.
вот код, который я использовал, чтобы получить поток !
TestDBDataContext context1 = new TestDBDataContext();
var r = (from a in context1.ImageTables where a.Id == 8 select a).First();
MemoryStream stream = new MemoryStream(r.FileImage.ToArray());
спасибо
5 ответов
то, что я сделал в прошлом, это установить url-адрес изображения на страницу aspx, например:
<img src="getLogo.aspx" alt="Logo" />
затем, в код для getLogo.aspx, я сделал следующее:
Response.BinaryWrite( imageData );
Response.ContentType = "image/gif";
здесь imageData
ваше изображение как массив байтов
Base64 кодирует ваш двоичный файл и вставляет в тег изображения следующим образом (измените тип mimetype на suit):
<img src=" ENCODED BINARY HERE">
вот как вы это сделаете, но я бы этого не сделал, так как некоторые браузеры не могут справиться с этим (IE6). Вам лучше сначала сохранить файл и сделать это обычным способом.
Я бы сохранил изображение в каталоге на веб-сайте, доступном внешним абонентам (т. е. подкаталог изображений), используя бессмысленное имя (например, первичный ключ записи в базе данных или GUID), затем добавьте href в этот файл на веб-странице.
сохранить поток памяти в файл с помощью:
MemoryStream memoryStream = new MemoryStream();
using (FileStream fileStream = new FileStream(FilePath, FileMode.Open, FileAccess.Write))
{
memoryStream.SaveTo(fileStream);
}
затем поместите имя файла в html.
сначала есть отдельный .файл aspx для изображения (на самом деле я бы предпочел перегрузку IHttpHandler для этого, но принцип тот же, и давайте введем только одну новую концепцию за раз).
The .файл aspx будет просто наследовать от кода и не будет иметь содержимого. Так что у него будет <%@ Page %>
директива и ничего больше.
в коде позади, в обработчике событий загрузки страницы, получите изображение и установите тип содержимого ответа на соответствующее значение (или, например, если все изображения являются image / png, вы можете просто жестко закодировать это). Затем запишите изображение на выход.
TestDBDataContext context1 = new TestDBDataContext();
int id;
if(int.TryParse(Request.QueryString["id"], out id))
{
var r = (from a in context1.ImageTables where a.Id == 8 select a).FirstOrDefault();
if(r != null)
{
Response.ContentType = r.ContentType;
Response.BinaryWrite(r.FileImage.ToArray());
return;
}
}
//code to handle 404 not found for no such image here (send error message or Server.Transfer to error page, etc.
затем вы можете использовать это с <img src="profileImg.aspx?id=8" alt="" />
etc.
повышение производительности заключается в получении байтов по 4k за раз из базы данных и записи их в Response.OutputStream
, а не один большой массив в памяти. Для небольших файлов разница неважна, но для очень больших файлов она может быть значительной (как в " Ура, теперь мой веб-сервер не падает уже не раз!" значительный.)