Anche se non è consigliabile memorizzare file binari come immagini in un database (l'ideale è memorizzare il file in una cartella sul disco fisso e tenere solo un riferimento ad esso in un campo di testo), il codice allegato può essere una buona fonte di studi perché viene mostrato come effettuare l'estrazione di dati in formato binaio da un database.
<%@ Import Namespace="System.IO"%> <%@ Import Namespace="System.Data"%> <%@ Import Namespace="System.Data.OleDb"%> <script runat="server" Language="C#"> void Page_Load(Object o,EventArgs e) { string db, strsql, idx; idx = Request.QueryString["id"]; if (idx == null) idx = "1"; db="immagini.mdb"; OleDbConnection myconnection = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0; Data Source="+Request.MapPath(db)); myconnection.Open(); strsql = "Select immagine,nome,contenttype FROM Tabella1 where id=" + idx; OleDbCommand mycommand = new OleDbCommand(strsql,myconnection); OleDbDataReader re = mycommand.ExecuteReader(); if (re.Read()) { Response.Clear(); Response.ClearContent(); Response.ContentType = re["contenttype"].ToString(); Response.BinaryWrite((byte[])re["immagine"]); } else Response.Write ("Nessuna immagine con questo ID"); re.Close(); myconnection.Close(); } </script>
Nell'allegato troverete il database Access con alcune immagini. Per visualizzarle dovremo passare come parametro l'id dell'immagine:
<img src="view_image.aspx?id=1">
In uno dei prossimi script vedremo come fare l'upload di immagini su database.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
I più letti di oggi
- Visualizzare contenuti Fullscreen con HTML5
- Leggere e scrivere su cookie tramite Blazor
- Richiamare programmaticamente le operazioni di aggiornamento, eliminazione e inserimento di FormView, DetailsView e GridView
- Realizzare siti sicuri con ASP.NET Web Pages
- Il web control DropDownList di ASP.NET
- Un helper method per replicare un template per ogni proprietà con ASP.NET MVC
- Operazioni di selezione su una DataTable
- Dependency injection in ASP.NET MVC 5 con Ninject
- Aumentare la scalabilità di ASP.NET Core Web API con caching client side
- Accedere con ASP.NET ad un documento XML creato dall'oggetto recordset di ADO e ASP