Asp.net mvc 在mvc中为本地计算机保存文件对话框

Asp.net mvc 在mvc中为本地计算机保存文件对话框,asp.net-mvc,savefiledialog,Asp.net Mvc,Savefiledialog,不知道有没有人能帮忙。我已经编写了这段代码,它将生成一个CSV文件电子表格并将其保存到指定位置。我想显示一个“另存为”对话框,从存储位置读取文件,然后询问用户,他们想将文件存储在哪里。excel文件不会生成,在下一个窗口中单击“导出到CSV”后,它将显示未定义为massege!然而,我的问题是,我编写的代码似乎是将文件直接输出到我的浏览器,因此我在浏览器屏幕上获得了CSV文件的所有内容,而没有按预期显示“另存为”对话框 这是我的密码 public ActionResult ExportToC

不知道有没有人能帮忙。我已经编写了这段代码,它将生成一个CSV文件电子表格并将其保存到指定位置。我想显示一个“另存为”对话框,从存储位置读取文件,然后询问用户,他们想将文件存储在哪里。excel文件不会生成,在下一个窗口中单击“导出到CSV”后,它将显示未定义为massege!然而,我的问题是,我编写的代码似乎是将文件直接输出到我的浏览器,因此我在浏览器屏幕上获得了CSV文件的所有内容,而没有按预期显示“另存为”对话框

这是我的密码

  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()
就可以做到这一点。