Improve company productivity with a Business Account.Sign Up

x
?
Solved

Code to download data from webpage.  File does not download.....IE displays the file instead of giving you the option to save the file to the local disk.

Posted on 2013-05-24
2
Medium Priority
?
440 Views
Last Modified: 2013-05-28
I have created a page where the users clicks a button inside a webgrid to download a file.  The row data is selected and the specific record is pulled from the database using LINQ.  The record found contains a binary field with some type of file stored in this field.  I want the page then to ask the user if they would like to save this file to the local hard drive.

What is currently happening is Internet Explorer attempts to display the content of the file.  For example, if the file was a .jpg, it displays the file on the screen.  It is nice but I want the file to prompt the user for downloading to their local machine.  Can someone tell me what I am doing wrong to make this code perform as I need it to.

Any help is greatly appreciated.


if (oButton.Text == "Download")
                {

                     DBDataContext dc= new DBDataContext();


                        string UploadIndex;

                        UploadIndex = oRow.Items[0].Value.ToString();


                        Guid guid = new Guid(UploadIndex);

                        

                        var UpLoadResult = from UpLoadData in dc.UpLoadBinaries
                                           where UpLoadData.UploadBinaryIndex == guid

                                           select UpLoadData;


                        
                        byte[] DownloadData = null;


                        // Pull the record
                        foreach (var UpLoadData in UpLoadResult)
                            try
                            {
                              
                                WebClient req = new WebClient();
                                HttpResponse response = HttpContext.Current.Response;
                                response.Clear();
                                response.ClearContent();
                                response.ClearHeaders();
                                response.Buffer = true;
                             
                                DownloadData = UpLoadData.Filedata.ToArray();
                                
                                response.BinaryWrite(DownloadData);
                                response.End();
                            }
                            catch (Exception ex)
                            {
                            }

                    }
                }

            }

Open in new window

0
Comment
Question by:kwh3856
2 Comments
 
LVL 85

Accepted Solution

by:
David Johnson, CD, MVP earned 2000 total points
ID: 39195611
we need to know what datatype is in the sql blob

               For Example ABC IS DATABASE FIELD OF Image DataType,
                 FileName, ContentType  is also saved in Database
                ContentType Examples are
                         Response.ContentType = "image/jpeg";
                         Response.ContentType = "image/gif";

 Only Need this Code to Download,

                         Response.ContentType = "FromDataBase";
                         string FileName = "FromDbData.jpeg"; //or gif or png as saved in DataBase
                         Response.AddHeader("Content-Disposition", "attachment; filename=" + FileName);
                         Response.BinaryWrite(ABC );

http://forums.asp.net/t/1396909.aspx/1
0
 

Author Closing Comment

by:kwh3856
ID: 39203235
Thank you very much.  Sorry for the delay in accepting.
0

Featured Post

Free Tool: SSL Checker

Scans your site and returns information about your SSL implementation and certificate. Helpful for debugging and validating your SSL configuration.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

It was really hard time for me to get the understanding of Delegates in C#. I went through many websites and articles but I found them very clumsy. After going through those sites, I noted down the points in a easy way so here I am sharing that unde…
Article by: Shaun
Tiling windows is a great way to see multiple applications at once. Windows Tiler is a tool that automatically tiles open application windows as the open and close.
Watch the video to know the simple way to remove or recover or reset lost or forgotten passwords of Outlook PST file. With Kernel Outlook Password Recovery tool such operation is very easy to perform. It is a freeware with limitation to use with 500…
Watch the video to know the process of migration of Exchange or Office 365 mailboxes in absence of MS Outlook. It is an eminent tool which can easily migrate Public, Archive user mailboxes from one another Exchange server and Office 365. Kernel Migr…

580 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question