Introduction
In my blog I am going to tell how to download files using a gridview in asp.net. I have used C# as my language. I am using Visual studio 2008 professional as my tool. If you wish you may use Visual studio 2005 as well. Also I am using MS SQL as my database server.
1. How to start
- First open visual studio.
- Then go to file->new->website
data:image/s3,"s3://crabby-images/efdf3/efdf38229af91cbc77863a783bbf875e86b5bd3c" alt=""
- Add a new website.
- I have named as download.
- I am saving it in my D drive in folder named as "Download".
data:image/s3,"s3://crabby-images/1db46/1db462aec122e81dbc6f03ee4bd53394b17d4d72" alt=""
2. Create a new database
- Add a new connection.
- Create a new database
- Create a table called download
- Create the table definitions as shown in the screen shot
Add connection
data:image/s3,"s3://crabby-images/79ae3/79ae348eaaa22c4e871459586cf9be58a117a244" alt="Add connection"
Create a database
data:image/s3,"s3://crabby-images/52a1e/52a1ebc9b361638e237588555fba021208ab7f89" alt="Create a database"
Create a new table
data:image/s3,"s3://crabby-images/57a85/57a857b1aec3336a3b4c020e2aa6c1cf8210c211" alt="Create a new table"
Include table defintion
data:image/s3,"s3://crabby-images/24a23/24a232de75db2e9483de1ae7ab54fc8a3f900d1a" alt="Include table defintion"
- downloadId - int with auto increment(as a primary key)
- fileName - varchar(50)
- fielPath - varchar(MAX)
Create a folder
- Create a folder to save some files
- It will be usefull for downloading example
Include some files inside the folder
data:image/s3,"s3://crabby-images/fe9af/fe9af7c89a2c5ded304cf4e12774896d298c7319" alt="Include some files inside the folder"
Adding data to the table
- Open table data
- Give the path of the saved files in the folder "download"
data:image/s3,"s3://crabby-images/af982/af98299a8673ba6475bf8c87404238549f0e0796" alt=""
3. Adding a gridview
- Drag an drop a gridview to your default page
- Then drag and drop a SQL data source to your page
Add grid view
data:image/s3,"s3://crabby-images/46055/4605506a840be49a2654c5052bf43c4e0442f869" alt="Add grid view"
4. Add sql datasource
data:image/s3,"s3://crabby-images/8c6f7/8c6f7db61418d0f25bf96db963c64b97a05a2353" alt="4. Add sql datasource"
The full view
data:image/s3,"s3://crabby-images/f4fed/f4fed0412f3f1d0ca444559702be86e51b6dfc44" alt="The full view"
configure datasource
data:image/s3,"s3://crabby-images/1f8a2/1f8a2b3f907ccf6a0dc0e75e82d875f197e52cd6" alt="configure datasource"
Choose connectin string
data:image/s3,"s3://crabby-images/49f8b/49f8b0de3d670538c7192a38b4b98f5168e75629" alt="Choose connectin string"
Select the table and fields
data:image/s3,"s3://crabby-images/9a066/9a0664b35458d1e5e71f24499c5e8415467f3559" alt="Select the table and fields"
Test the query
data:image/s3,"s3://crabby-images/5c75f/5c75faed0b97384f7a65ff81886cdfbf53082f8d" alt="Test the query"
Choose datasource for Gridview
data:image/s3,"s3://crabby-images/8a2da/8a2da01efe4f80cae0e56ca7f7ff58692e0a8e4c" alt="Choose datasource for Gridview"
Remove fields
data:image/s3,"s3://crabby-images/73f9d/73f9dd46013dcd33b5c5d1afefa0aabaa93d79a3" alt="Remove fields"
Change field names
data:image/s3,"s3://crabby-images/4effc/4effca9e9f482411e756a1471f6dfc307ee87f60" alt="Change field names"
View
data:image/s3,"s3://crabby-images/01017/01017f89319582e9e3cac40688b8c655705fdba5" alt="View"
Choose a format
data:image/s3,"s3://crabby-images/93d4a/93d4a0e46b49fbd421e148d1afa2eb795f3f7e45" alt="Choose a format"
5. Create Appcode
data:image/s3,"s3://crabby-images/bfc05/bfc0521a0a8e62c8e1897f708b801d7577578ee9" alt="5. Create Appcode"
Go to asp.net folder and choose appcode
Create a class called ConnectionManager
data:image/s3,"s3://crabby-images/1c751/1c751803e1a6f4ce602bdb11c628d7beb973eed7" alt="Create a class called ConnectionManager"
Code inside the ConnectionManager class
using System;
using System.Data;
using System.Configuration;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq;
using System.Data.SqlClient;
public class ConnectionManager
{
public static SqlConnection GetDatabaseConnection()
{
string connectString = "Data Source=VINO-PC\\SQLEXPRESS;Initial Catalog=download;Integrated Security=True";
SqlConnection connection=new SqlConnection(connectString);
connection.Open();
return connection;
}
Create another class called download
data:image/s3,"s3://crabby-images/02d04/02d044883ed04ff00a4af92c52f4f786ecd08ef5" alt="Create another class called download"
Code in download class(getting the selected file path)
using System;
using System.Data;
using System.Configuration;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq;
using System.Data.SqlClient;
public class download
{
public download()
{
}
public static DataSet GetresourcePath(int downloadId)
{
DataSet dataSet = new DataSet();
using (SqlConnection connection = ConnectionManager.GetDatabaseConnection())
{
string sql = "SELECT filePath FROM Download WHERE downloadId=@downloadId";
SqlCommand command = new SqlCommand(sql, connection);
command.Parameters.Add("@downloadId", SqlDbType.VarChar).Value = downloadId;
command.CommandType = CommandType.Text;
SqlDataAdapter dataAdapter = new SqlDataAdapter(command);
dataAdapter.Fill(dataSet, "filePath");
}
return dataSet;
}
}
Code behind for Default.aspx page(Default.aspx.cs)
using System;
using System.Configuration;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq;
using System.Data.SqlClient;
using System.IO;
public partial class _Default : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
}
protected void GridView1_SelectedIndexChanged(object sender, EventArgs e)
{
try
{
int fileindex = (int)GridView1.SelectedValue;
string dbPath = null;
DataSet path = download.GetresourcePath(fileindex);
foreach (DataRow row in path.Tables["filePath"].Rows)
{
dbPath = string.Format("{0}", row["filePath"]);
}
string filePath = @dbPath;
string fileName = Path.GetFileName(filePath);
System.IO.Stream stream = null;
stream = new FileStream(filePath, System.IO.FileMode.Open, System.IO.FileAccess.Read, System.IO.FileShare.Read);
long bytesToRead = stream.Length;
Response.ContentType = "application/octet-stream";
Response.AddHeader("content-Disposition", "attachment; filename=" + fileName);
while (bytesToRead > 0)
{
if (Response.IsClientConnected)
{
byte[] buffer = new Byte[10000];
int length = stream.Read(buffer, 0, 10000);
Response.OutputStream.Write(buffer, 0, length);
Response.Flush();
bytesToRead = bytesToRead - length;
}
else
{
bytesToRead = -1;
}
}
}
catch (Exception ex)
{
}
}
}
Code behind detail
- To get the GridView1_SelectedIndexChanged method double click on the download link in the gridview.
- So it automatically create the method
- You may type the code I have given.
6. Now run and you may download your files
data:image/s3,"s3://crabby-images/504c6/504c60aefec931c4735fe74d8d7571491579dbb3" alt="6. Now run and you may download your files"
If you are facing trouble then you can try this following link also
Thanks Shibashish Mohanty
No comments:
Post a Comment
Please don't spam, spam comments is not allowed here.