在C#中,我们可以使用ASP.NET AJAX技术来处理文件上传和下载。这里,我们将介绍一种简单的方法来实现这个功能。
首先,在HTML页面中添加一个FileUpload控件和一个Button控件:
<asp:FileUpload ID="FileUpload1" runat="server" />
<asp:Button ID="btnUpload" runat="server" Text="Upload" OnClick="btnUpload_Click" />
接下来,在服务器端代码中编写文件上传的逻辑:
protected void btnUpload_Click(object sender, EventArgs e)
{
if (FileUpload1.HasFile)
{
string fileName = Path.GetFileName(FileUpload1.PostedFile.FileName);
FileUpload1.PostedFile.SaveAs(Server.MapPath("~/Uploads/") + fileName);
Response.Write("File Uploaded!");
}
else
{
Response.Write("Please Select File to Upload");
}
}
在HTML页面中添加一个GridView控件和一个Button控件:
<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False">
<Columns>
<asp:BoundField DataField="Name" HeaderText="File Name" />
<asp:TemplateField>
<ItemTemplate>
<asp:LinkButton ID="lnkDownload" runat="server" Text="Download" OnClick="lnkDownload_Click"></asp:LinkButton>
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>
<asp:Button ID="btnShowFiles" runat="server" Text="Show Files" OnClick="btnShowFiles_Click" />
接下来,在服务器端代码中编写文件下载的逻辑:
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
LoadFiles();
}
}
private void LoadFiles()
{
string[] files = Directory.GetFiles(Server.MapPath("~/Uploads/"));
List<ListItem> items = new List<ListItem>();
foreach (string file in files)
{
items.Add(new ListItem(Path.GetFileName(file), file));
}
GridView1.DataSource = items;
GridView1.DataBind();
}
protected void lnkDownload_Click(object sender, EventArgs e)
{
LinkButton lnkbtn = sender as LinkButton;
GridViewRow gvrow = lnkbtn.NamingContainer as GridViewRow;
string filePath = GridView1.DataKeys[gvrow.RowIndex].Value.ToString();
Response.ContentType = "application/octet-stream";
Response.AppendHeader("Content-Disposition", "attachment; filename=" + Path.GetFileName(filePath));
Response.TransmitFile(filePath);
Response.End();
}
protected void btnShowFiles_Click(object sender, EventArgs e)
{
LoadFiles();
}
这样,我们就实现了使用C#和ASP.NET AJAX技术处理文件上传和下载的功能。当然,这只是一个简单的示例,你可以根据自己的需求进行修改和优化。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。