ARTICLE

File Upload in Silverlight

Posted by Nipun Tomar Articles | Silverlight with C# March 19, 2009
This article describes how to upload files on the Web in a Silverlight application.
Reader Level:
Download Files:
 

In this article, I will discuss how you can create your own File Upload feature in a Silverlight application.

Step 1: First, create a Silverlight Web application in Visual Studio 2008. You will see your default Page.xaml.

Step 2: On Create Page.xaml, change your code by adding following Panel, Button, and TextBlock controls.

On buttin click event handler, I write code to call the OpenFileDialog that allows us to browse files and gives us the selected file name. Here is the code. 

public void Button_Click(object sender, RoutedEventArgs e)
        {
            OpenFileDialog dlg = new OpenFileDialog();          
            dlg.Multiselect = false;
            dlg.Filter = "All files (*.*)|*.*|PNG Images (*.png)|*.png";

            bool? retval = dlg.ShowDialog();

            if (retval != null && retval == true)
            {
                UploadFile(dlg.File.Name, dlg.File.OpenRead());
                StatusText.Text = dlg.File.Name;
            }
            else
            {
                StatusText.Text = "No file selected...";
            }
        }


As you can see from the above code, I call a method UploadFile by passing the selected file name from the OpenFileDialog.

The UploadFile method looks like following. In this code, I use a WebClient class and a PushData method.

private void UploadFile(string fileName, Stream data)
        {
            UriBuilder ub = new UriBuilder("http://localhost:3840/receiver.ashx");
            ub.Query = string.Format("filename={0}", fileName);

            WebClient c = new WebClient();
            c.OpenWriteCompleted += (sender, e) =>
            {
                PushData(data, e.Result);
                e.Result.Close();
                data.Close();
            };
            c.OpenWriteAsync(ub.Uri);
        }

        private void PushData(Stream input, Stream output)
        {
            byte[] buffer = new byte[4096];
            int bytesRead;

            while ((bytesRead = input.Read(buffer, 0, buffer.Length)) != 0)
            {
                output.Write(buffer, 0, bytesRead);
            }
        }

Step 3: Add a new Generic Handler receiver.ashx.

Now let's add a class. Right click on the project and Add a new item by selecting Generic Handler in the right side templates as shown below.



And add the following code on the coe behind:

<%@ WebHandler Language="C#" Class="receiver" %>

using System;
using System.Web;
using System.IO;

public class receiver : IHttpHandler {

       public void ProcessRequest (HttpContext context) {
        string filename = context.Request.QueryString["filename"].ToString();

        using (FileStream fs = File.Create(context.Server.MapPath("~/App_Data/" + filename)))
        {
            SaveFile(context.Request.InputStream, fs);
        }
    }

    private void SaveFile(Stream stream, FileStream fs)
    {
        byte[] buffer = new byte[4096];
        int bytesRead;
        while ((bytesRead = stream.Read(buffer, 0, buffer.Length)) != 0)
        {
            fs.Write(buffer, 0, bytesRead);
        }
    }
 
    public bool IsReusable {
        get {
            return false;
        }
    }
}


Step 4: Build and Run

That's all. You are done. Now just build and run your project. 

When you click the Select File button, you will see Browse files dialog that lets you browse the files.

 

Note: You need to make sure your folder on the Web has write permissions to upload files.

 


 

Login to add your contents and source code to this article
Article Extensions
Contents added by Di Sl on Mar 12, 2010
Super !!!
Contents added by Iurii on Jan 19, 2010
Thank you!!!
post comment
     

Hello, when I try to upload a file of 5 Mb, I get a HttpException "Maximum request length exceeded" around context.Request.InputStream

Posted by jesus Apr 11, 2013

awesomeeeeeee

Posted by Anant Singh Jun 23, 2012

Nice example Nipur, But I need file upload with drag and drop functionality, it is nice you can provide a sample example. Thanks, Mohan

Posted by Mohan Singh Feb 20, 2012

Hi Nipur, I am new in silverlight and need one favour. Drag and drop file and upload to server using silver light in IE. Thanks

Posted by Mohan Singh Feb 16, 2012

Hello Nipun,. i have downloaded the .zip file for file uploader. When i extracted it & then saw the references, System.Web.Silverlight is corrupted,so i deleted it & now my Question is,from where to add the new reference for System.Web.Silverlight? please reply quick

Posted by Burhan Saiyed Feb 01, 2012
COMMENT USING
PREMIUM SPONSORS
DynamicPDF™ product line allows you to dynamically generate PDF documents, merge PDF documents and add new content to existing PDF documents from within your applications.
SPONSORED BY
  • PDF reports have never been easier to create. With our included WYSIWYG Designer, you can layout your reports, set up your data source and let DynamicPDF ReportWriter do the rest.
Join a Chapter