我有一个MVC项目,我希望用户能够通过单击按钮下载excel文件。我有文件的路径,我似乎无法通过谷歌找到我的答案。
我希望能够通过我的cshtml页面上的一个简单按钮来完成此操作:
<button>Button 1</button>
我该怎么做?非常感谢任何帮助!
答案 0 :(得分:16)
如果文件不在您的应用程序文件夹中,并且无法直接从客户端访问,则可以使用控制器操作将文件内容流式传输到客户端。这可以通过使用File
方法从控制器操作返回FileResult
来实现:
public ActionResult Download()
{
string file = @"c:\someFolder\foo.xlsx";
string contentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
return File(file, contentType, Path.GetFileName(file));
}
然后用指向此控制器操作的锚点替换您的按钮:
@Html.ActionLink("Button 1", "Download", "SomeController")
除了使用锚之外,您还可以使用html表单:
@using (Html.BeginForm("Download", "SomeController", FormMethod.Post))
{
<button type="submit">Button 1</button>
}
如果文件位于某些不可从应用程序的客户端文件夹访问的文件中,例如App_Data
,则可以使用MapPath
方法使用相对路径构建此文件的完整物理路径:
string file = HostingEnvironment.MapPath("~/App_Data/foo.xlsx");
答案 1 :(得分:2)
HTML:
<div>@Html.ActionLink("UI Text", "function_name", "Contoller_name", new { parameterName = parameter_value },null) </div>
控制器:
public FileResult download(string filename) {
string path = "";
var content_type = "";
path = Path.Combine("D:\file1", filename);
if (filename.Contains(".pdf"))
{
content_type = "application/pdf";
}
return File(path, content_type, filename);
}