Hi Hazel,
Please refer below sample.
HTML
<div id="MyPopup" class="modal fade" role="dialog">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
</div>
<div class="modal-title">
</div>
<div class="modal-body">
<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="false">
<Columns>
<asp:BoundField DataField="Text" HeaderText="File Name" />
<asp:TemplateField>
<ItemTemplate>
<asp:ImageButton AlternateText="Open" CommandArgument='<%# Eval("Value") %>'
runat="server" OnClick="OnOpen"></asp:ImageButton>
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
</div>
<div class="modal-footer"></div>
</div>
</div>
</div>
Namespaces
C#
using System.IO;
using System.Text;
VB.Net
Imports System.IO
Imports System.Text
Code
Default
C#
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
string[] filePaths = Directory.GetFiles(Server.MapPath("~/Images/"));
List<ListItem> files = new List<ListItem>();
foreach (string filePath in filePaths)
{
files.Add(new ListItem(Path.GetFileName(filePath), Path.GetFileName(filePath)));
}
GridView1.DataSource = files;
GridView1.DataBind();
}
}
protected void OnOpen(object sender, ImageClickEventArgs e)
{
string fileName = (sender as ImageButton).CommandArgument;
string url = "Download.aspx?FileName=" + fileName;
StringBuilder sb = new StringBuilder();
sb.Append("<script type = 'text/javascript'>");
sb.Append("window.open('");
sb.Append(url);
sb.Append("');");
sb.Append("</script>");
ClientScript.RegisterStartupScript(this.GetType(), "script", sb.ToString());
}
VB.Net
Protected Sub Page_Load(ByVal sender As Object, ByVal e As EventArgs) Handles Me.Load
If Not IsPostBack Then
Dim filePaths As String() = Directory.GetFiles(Server.MapPath("~/Images/"))
Dim files As List(Of ListItem) = New List(Of ListItem)()
For Each filePath As String In filePaths
files.Add(New ListItem(Path.GetFileName(filePath), Path.GetFileName(filePath)))
Next
GridView1.DataSource = files
GridView1.DataBind()
End If
End Sub
Protected Sub OnOpen(ByVal sender As Object, ByVal e As ImageClickEventArgs)
Dim fileName As String = (TryCast(sender, ImageButton)).CommandArgument
Dim url As String = "DownloadVB.aspx?FileName=" & fileName
Dim sb As StringBuilder = New StringBuilder()
sb.Append("<script type = 'text/javascript'>")
sb.Append("window.open('")
sb.Append(url)
sb.Append("');")
sb.Append("</script>")
ClientScript.RegisterStartupScript(Me.GetType(), "script", sb.ToString())
End Sub
Download
C#
protected void Page_Load(object sender, EventArgs e)
{
string filePath = Server.MapPath("~/Images/" + Request.QueryString["FileName"]);
System.IO.FileInfo file = new System.IO.FileInfo(filePath);
if (file.Exists)
{
Response.ClearContent();
Response.AddHeader("Content-Disposition", "inline; filename=" + file.Name);
Response.AddHeader("Content-Length", file.Length.ToString());
Response.ContentType = ReturnExtension(file.Extension.ToLower());
Response.TransmitFile(file.FullName);
Response.End();
}
}
private string ReturnExtension(string fileExtension)
{
switch (fileExtension)
{
case ".jpg":
return "image/jpg";
case ".jpeg":
return "image/jpeg";
default:
return "application/pdf";
}
}
VB.Net
Protected Sub Page_Load(ByVal sender As Object, ByVal e As EventArgs) Handles Me.Load
Dim filePath As String = Server.MapPath("~/Images/" & Request.QueryString("FileName"))
Dim file As System.IO.FileInfo = New System.IO.FileInfo(filePath)
If file.Exists Then
Response.ClearContent()
Response.AddHeader("Content-Disposition", "inline; filename=" & file.Name)
Response.AddHeader("Content-Length", file.Length.ToString())
Response.ContentType = ReturnExtension(file.Extension.ToLower())
Response.TransmitFile(file.FullName)
Response.End()
End If
End Sub
Private Function ReturnExtension(ByVal fileExtension As String) As String
Select Case fileExtension
Case ".jpg"
Return "image/jpg"
Case ".jpeg"
Return "image/jpeg"
Case Else
Return "application/pdf"
End Select
End Function
JQuery
<script type="text/javascript">
$(document).ready(function () {
$("#MyPopup").modal("show");
});
</script>
Screenshot