Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Artiklar / Titel på artikeln

FileUpload med UpdatePanel

Postad 2007-09-30 av David Hägg i sektionen ASP.NET, C#, Okategoriserat med 0 Kommentarer | Läst av: 5487, Betyg: 100%

Förord

FileUpload kontrollen i ASP.NET fungerar inte tillsammans med UpdatePanel eftersom en asynkron uppladdning av en fil inte är möjlig. Det går däremot att använda en iFrame för att slippa att hela sidan laddas om. Denna artikel innehåller kodexempel på hur en sådan lösning kan se ut. Du kan ladda ner alla filer som en zip-fil här
Innehåll
  » Webbform med UpdatePanel (Default.aspx)
  » GUI för uppladdning (UploadFile.aspx)
  » GUI för uppladdning CodeBehind (UploadFile.aspx.cs)
  » Progressbar för att visa status på uppladdningen



Webbform med UpdatePanel (Default.aspx)

Först skapar vi en helt vanlig WebForm som innehåller en ScriptManager, UpdatePanel och en iFrame som pekar på vår UploadFiles.aspx WebForm som sköter själva uppladdningen.



















style="display:none;"
UseSubmitBehavior="false"
runat="server"
OnClick="btnUploadedAsync_Click" />













GUI för uppladdning (UploadFile.aspx)

Detta är filen som iFramen pekar på från Default.aspx. Denna filen innehåller ett grafiskt gränssnitt för att ladda upp filen. Själva uppladdningen sker alltså inte asynkront, men besökaren får känslan av det eftersom själva huvudsidan inte laddas om.

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="UploadFiles.aspx.cs" Inherits="UploadFilesAsync" %>

<%@ Register Assembly="System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
Namespace="System.Web.UI" TagPrefix="asp" %>





Ladda upp filer


<script language="javascript" type="text/javascript">

// Funktion som triggas när en fil har valts
function UploadFile()
{
// Posta filen
document.form1.btnUploadAsync.click();

// Visa progress bild
document.getElementById('iframeProgress').style.display = 'block';

// Göm upload boxen
document.form1.uploadAsync.style.display = 'none';
}
</script>









Ladda upp fil







OnClick="btnUploadAsync_Click"
style="display:none;" />







OnClick="lnkTryAgain_Click"
Text="Försök igen">










OnClick="btnEraseFile_Click"
ToolTip="Radera filen"
AlternateText="Radera"
ImageUrl="btn_del.png"
style="padding-left: 10px;">














GUI för uppladdning CodeBehind (UploadFile.aspx.cs)

public partial class UploadFilesAsync : System.Web.UI.Page
{
// Mapp över applikationsroten som filen skall sparas i, måste ha write permissions
private static string BaseSaveFolder = "_PublicFiles";

protected void Page_Load(object sender, EventArgs e)
{
if (!Page.IsPostBack)
{
// Trigga upload när en fil har valts
uploadAsync.Attributes.Add("onchange", "UploadFile()");

// Lägg till bekräftelse när filen skall tas bort
btnDelLink.Attributes.Add("onclick", "return confirm('Vill du verkligen ta bort denna fil?')");

// Göm panelen med felmeddelande
pnlFailed.Visible = false;
}

// If a file is uploaded then show it
if (Session["SavedPublicFile"] != null &&
Session["SavedFileName"] != null)
{
ShowUploadedFile();
}

}

#region Event methods

///
/// Sparar den valda filen till serverns filsystem
///

protected void btnUploadAsync_Click(object sender, EventArgs e)
{
try
{
// Ställ in målmapp och publik målmapp
string savePath = Request.PhysicalApplicationPath + BaseSaveFolder + @"\";
string savePublicPath = ResolveUrl("http://" + Request.ServerVariables["SERVER_NAME"] + Request.ApplicationPath + @"/" + BaseSaveFolder + "/");

// Skapa katalogen om den inte existerar
if (!Directory.Exists(savePath))
{
Directory.CreateDirectory(savePath);
}

// Kontrollera att upload boxen innehåller en fil
if (uploadAsync.HasFile)
{
// Hämta filen storlek i bytes
int fileSize = uploadAsync.PostedFile.ContentLength;

// Tillåt endast max 2MB stora filer.
// OBS! Om större filer än 4MB skall laddas upp måste web.config modifieras
// All data som är större än 256KB sparas ner på serverns disk innan den slutgiltiga filen sparas
// Detta gör att serverns minne inte tas upp av uppladdade filer.
if (fileSize < 2100000)
{
// Hämta filens namn
string fileName = uploadAsync.FileName;

// Hämta filens ändelse
string extension = System.IO.Path.GetExtension(fileName);

// Begränsa filändelser som tillåts
if ((extension == ".doc") |
(extension == ".xls") |
(extension == ".htm") |
(extension == ".html") |
(extension == ".pdf") |
(extension == ".docx") |
(extension == ".rtf"))
{

// Om filen finns, skapa ett unikt filnamn
int i = 1;
while (File.Exists(savePath + fileName))
{
fileName = fileName.Substring(0, (fileName.Length - extension.Length)) +
"_" + i.ToString() + extension;
i++;
}

// Spara den fullständiga sökvägen till filen
savePath += fileName;
savePublicPath += fileName;

// Spara filen på disk
uploadAsync.SaveAs(savePath);

// Spara referenser till filen i sessionen
Session["SavedFile"] = savePath;
Session["SavedPublicFile"] = savePublicPath;
Session["SavedFileName"] = fileName;

// Visa den uppladdade filen
ShowUploadedFile();
}
else
{
// Felaktig filändelse
pnlFailed.Visible = true;
pnlFileUpload.Visible = false;
lblUploadStatus.Text = "Felaktig filtyp! Kontrollera filändelsen.";
}
}
else
{
// För stor fil
pnlFailed.Visible = true;
pnlFileUpload.Visible = false;
lblUploadStatus.Text = "Du får maximalt ladda upp 2MB stora filer";
}

}
}
catch (Exception ex)
{
// Ett oväntat fel uppstod
pnlFailed.Visible = true;
pnlFileUpload.Visible = false;
lblUploadStatus.Text = ex.Message;
}
}

///
/// Tar bort en uppladdad fil från disken
///

protected void btnEraseFile_Click(object sender, EventArgs e)
{
// Ta bort filen om den finns
if (File.Exists(Session["SavedFile"].ToString()))
{
File.Delete(Session["SavedFile"].ToString());
}

// Töm sessionsvariablerna
Session["SavedFile"] = null;
Session["SavedPublicFile"] = null;
Session["SavedFileName"] = null;

// Visa upload boxen
ShowUploadBox();
}

///
/// Visar upload boxen igen
///

protected void lnkTryAgain_Click(object sender, EventArgs e)
{
ShowUploadBox();
}

#endregion

#region Show methods

///
/// Visar den uppladdade filen från en referens som sparats i sessionen
///

private void ShowUploadedFile()
{
lnkUploadedFile.Text = Session["SavedFileName"].ToString();
lnkUploadedFile.NavigateUrl = Session["SavedPublicFile"].ToString();
pnlFileUpload.Visible = false;
pnlFileUploaded.Visible = true;
}

///
/// Visar upload boxen
///

private void ShowUploadBox()
{
pnlFileUpload.Visible = true;
pnlFileUploaded.Visible = false;
pnlFailed.Visible = false;
}

#endregion

}



Progressbar för att visa status på uppladdningen

Vi skapar ytterligare en sida för att kunna visa besökaren en bild som rör sig när filen laddas upp. Detta är bara en enkel html sida som visar en gif bild. Denna sida länkas in genom en iframe från FileUpload.aspx




Progress Bar









Detta är allt som behövs för att göra en filuppladdning som ser ut som en asynkron uppladdning för din besökare.

Du kan ladda ner alla filer som en zip-fil här
Upp

0 Kommentarer

Skriv en kommentar på artikeln

Ditt betyg på artikeln



Kommentar:





Nyligen

  • 09:09 Vill du köpa medicinska tester?
  • 12:47 Vem beviljar assistansen – kommune
  • 14:17 Någon med erfarenhet av hemstädnin
  • 14:14 Bör man använda sig av en båtförme
  • 14:12 Finns det någon intressant hundblo
  • 14:25 Tips på verktyg för att skapa QR-k
  • 14:23 Tips på verktyg för att skapa QR-k
  • 20:52 Fungerer innskuddsbonuser egentlig

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 569 153
27 952
271 704
1 341
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies