Sqlserver
 sql >> Datenbank >  >> RDS >> Sqlserver

Speichern Sie die Datei in der SQL Server-Datenbank mit .Net MVC3 mit Entity Framework

Hier sind einige "Beispielcodes";) Ich habe eine Reihe von Deklarationen, Validierungen usw. weggelassen, sodass der Code nicht so ausgeführt wird, wie er ist, aber Sie sollten in der Lage sein, die Idee zu verstehen. Verwenden Sie eine Anfrage vom Typ Ajax, um Ihr Dateiformular zu senden, wenn Sie die Seite nicht aktualisieren möchten.

// model
public class UploadedImage
{
    public int UploadedImageID { get; set; }
    public string ContentType { get; set; }
    public byte[] File { get; set; }
}

// controller
public ActionResult Create()
{
    HttpPostedFileBase file = Request.Files["ImageFile"];

    if (file.ContentLength != 0)
    {
        UploadedImage img = new UploadedImage();
        img.ContentType = file.ContentType;
        img.File = new byte[file.ContentLength];

        file.InputStream.Read(img.File, 0, file.ContentLength);

        db.UploadedImages.Add(img);
        db.SaveChanges();
    }

    return View();
}

ActionResult Show(int id) 
{
    var image = db.UploadedImages.Find(id);
    if (image != null)
    {
        return File(image.File, image.ContentType, "filename goes here");
    }
}