Verwenden von ASP.NET MVC und SQL Server 2016. Ich habe Anlagen, die als Binärdaten in SQL Server gespeichert.ASP.NET MVC Liste der Anlagen (aus Binärdaten)
Tabelle mit Daten wie folgt aussieht:
attachment_ID | attachment_GUID | attachment_data | attachment_name|
--------------|------------------|-----------------|----------------|
211 | A893C2Z1-4C0 | 0x255044462... | file1.doc |
212 | A893C2R5-4F0 | 0x255044455... | file5.pdf |
I Liste dieser Anhänge angezeigt werden müssen (Namen), als Hyperlinks in HTML-Seite. Wenn ich also auf den Namen des Anhangs klicke, sollte der Download-Vorgang gestartet werden.
Brauchen Sie Hilfe mit einem ASP.NET MVC-Controller.
Ich habe Controller, die eine Datei direkt heruntergeladen:
using System;
using System.Data.SqlClient;
using System.IO;
using System.Web;
using System.Web.Mvc;
using System.Collections.Generic;
namespace Project.SERVER.Controllers
{
public class AttachmenttoHTMLController : Controller
{
#region View attachments
[HttpGet]
public ActionResult Get()
{
SqlConnection connection = Project.SERVER.Classes.INT_DataBase.getConnection();
SqlCommand command = new SqlCommand("SELECT * FROM AllAttachments WHERE document_GUID='F3A2AC32-D98D'", connection);
command.Dispose();
SqlDataAdapter sqlDtAdptr = new SqlDataAdapter(command);
System.Data.DataTable result = new System.Data.DataTable();
result.Dispose();
sqlDtAdptr.Fill(result);
sqlDtAdptr.Dispose();
connection.Dispose();
connection.Close();
if (result.Rows.Count > 0 && !System.Convert.IsDBNull(result.Rows[0]["attachment_data"]))
{
byte[] file = (byte[])result.Rows[0]["attachment_data"];
Response.ContentType = result.Rows[0]["attachment_contentType"].ToString();
return File(file, Response.ContentType, result.Rows[0]["attachment_fileName"].ToString());
}
else return new EmptyResult();
}
#endregion
}
}
Was soll ich mit dem Code hinzufügen, mit der Option zu erreichen Controller für Anlagenliste zum Download, wenn darauf geklickt?
Angenommen, Ihr 'Capture.PNG' befindet sich innerhalb des' Image'-Ordners unter Ihrem Projektverzeichnis. –
Wenn Sie viele Dateien von Ihrer DB haben, können Sie sie mit einer Schleife in Ihr HTML einfügen, um einen Link für jede einzelne Datei zu erstellen. –
Ich brauchte eine Weile, um es herauszufinden und zu reproduzieren. Diese Lösung funktioniert, danke für Ihre Hilfe! – Dmitry