Asp.net mvc 在mvc中为本地计算机保存文件对话框
不知道有没有人能帮忙。我已经编写了这段代码,它将生成一个CSV文件电子表格并将其保存到指定位置。我想显示一个“另存为”对话框,从存储位置读取文件,然后询问用户,他们想将文件存储在哪里。excel文件不会生成,在下一个窗口中单击“导出到CSV”后,它将显示未定义为massege!然而,我的问题是,我编写的代码似乎是将文件直接输出到我的浏览器,因此我在浏览器屏幕上获得了CSV文件的所有内容,而没有按预期显示“另存为”对话框 这是我的密码Asp.net mvc 在mvc中为本地计算机保存文件对话框,asp.net-mvc,savefiledialog,Asp.net Mvc,Savefiledialog,不知道有没有人能帮忙。我已经编写了这段代码,它将生成一个CSV文件电子表格并将其保存到指定位置。我想显示一个“另存为”对话框,从存储位置读取文件,然后询问用户,他们想将文件存储在哪里。excel文件不会生成,在下一个窗口中单击“导出到CSV”后,它将显示未定义为massege!然而,我的问题是,我编写的代码似乎是将文件直接输出到我的浏览器,因此我在浏览器屏幕上获得了CSV文件的所有内容,而没有按预期显示“另存为”对话框 这是我的密码 public ActionResult ExportToC
public ActionResult ExportToCSSReport(List<CEPMobility.CEPServiceProxy.CSSReport> Report)
{
MemoryStream output = new MemoryStream();
StreamWriter writer = new StreamWriter(output, System.Text.Encoding.UTF8);
writer.WriteLine("PROJECT NAME,CSS ID,CSS Name,Customer Reprentative Name,CSS Recived Date,CSI,TOP 3 STRENGTH,TOP 3 OFI,Any Other COMMENT");
foreach (CEPMobility.CEPServiceProxy.CSSReport objreport in Report)
{
writer.WriteLine("\"" + objreport.PROJECT_NAME + "\",\"" + objreport.CSS_ID + "\",\"" + objreport.CSS_NAME + "\",\"" + objreport.CUST_REP_NAME + "\",\"" + objreport.CSS_RECIEVED_DT + "\",\"" + objreport.CSI + "\",\"" + objreport.TOP_3_STRENGTH + "\",\"" + objreport.TOP_3_OFI + "\",\"" + objreport.COMMENT + "\"");
}
writer.Flush();
output.Seek(0, SeekOrigin.Begin);
return File(output, "text/csv", "CSSReport.csv");
}
public ActionResult exporttocsreport(列表报告)
{
MemoryStream输出=新的MemoryStream();
StreamWriter=新的StreamWriter(输出,System.Text.Encoding.UTF8);
writer.WriteLine(“项目名称、CSS ID、CSS名称、客户代表姓名、CSS接收日期、CSI、前三强、前三OFI、任何其他评论”);
foreach(报告中的CEPMobility.CEPServiceProxy.CSS报告objreport)
{
writer.WriteLine(“\”+objreport.PROJECT\u NAME+“\”、“+objreport.CSS\u ID+“\”、“+objreport.CSS\u NAME+”、“\”+objreport.CUST\u repu NAME+”、“+objreport.CSS\u接收到的DT+”、“+objreport.CSI+”、“+objreport.CSI+”、“+objreport.TOP\u 3”、“+objreport+”)、+;
}
writer.Flush();
Seek(0,SeekOrigin.Begin);
返回文件(输出,“text/csv”、“CSSReport.csv”);
}
作为对gor的响应,它将在顶部显示相同的未定义消息:
public ActionResult ExportToCSSReport(List<CEPMobility.CEPServiceProxy.CSSReport> Report)
{
CEPServiceProxy.CEPDataServiceClient client = null;
client = new CEPServiceProxy.CEPDataServiceClient();
lstCSSReport = client.GetCSSReport(cSS_NAME, in_Cust_ID).ToList();
MemoryStream output = new MemoryStream();
StreamWriter writer = new StreamWriter(output, System.Text.Encoding.UTF8);
writer.WriteLine("PROJECT NAME,CSS ID,CSS Name,Customer Reprentative Name,CSS Recived Date,CSI,TOP 3 STRENGTH,TOP 3 OFI,Any Other COMMENT");
foreach (CEPMobility.CEPServiceProxy.CSSReport objreport in Report)
{
writer.WriteLine("\"" + objreport.PROJECT_NAME + "\",\"" + objreport.CSS_ID + "\",\"" + objreport.CSS_NAME + "\",\"" + objreport.CUST_REP_NAME + "\",\"" + objreport.CSS_RECIEVED_DT + "\",\"" + objreport.CSI + "\",\"" + objreport.TOP_3_STRENGTH + "\",\"" + objreport.TOP_3_OFI + "\",\"" + objreport.COMMENT + "\"");
}
writer.Flush();
output.Seek(0, SeekOrigin.Begin);
Response.AddHeader("Content-Disposition", "attachment;filename=CSSReport.csv");
return File(output, "text/csv", "CSSReport.csv");
}
public ActionResult exporttocsreport(列表报告)
{
CEPServiceProxy.CEPDataServiceClient=null;
client=新的CEPServiceProxy.CEPDataServiceClient();
lstCSSReport=client.GetCSSReport(cSS_NAME,in_Cust_ID).ToList();
MemoryStream输出=新的MemoryStream();
StreamWriter=新的StreamWriter(输出,System.Text.Encoding.UTF8);
writer.WriteLine(“项目名称、CSS ID、CSS名称、客户代表姓名、CSS接收日期、CSI、前三强、前三OFI、任何其他评论”);
foreach(报告中的CEPMobility.CEPServiceProxy.CSS报告objreport)
{
writer.WriteLine(“\”+objreport.PROJECT\u NAME+“\”、“+objreport.CSS\u ID+“\”、“+objreport.CSS\u NAME+”、“\”+objreport.CUST\u repu NAME+”、“+objreport.CSS\u接收到的DT+”、“+objreport.CSI+”、“+objreport.CSI+”、“+objreport.TOP\u 3”、“+objreport+”)、+;
}
writer.Flush();
Seek(0,SeekOrigin.Begin);
AddHeader(“内容处置”、“附件;文件名=CSSReport.csv”);
返回文件(输出,“text/csv”、“CSSReport.csv”);
}
您应该在回复中添加内容处置标题。像这样:
Response.AddHeader("Content-Disposition", "attachment;filename=CSSReport.csv");
不需要,
Controller.File()
就可以做到这一点。