3

我有一个具有以下方法的控制器:

public void ExportList()
{
    var out = GenExport();

    CsvExport<LiveViewListe> csv = new CsvExport<LiveViewListe>(out);
    Response.Write(csv.Export());
}

这应该生成一个用户可以下载的 csv 文件。

在我看来,我通过 jQuery 请求调用此方法:

$.getJSON('../Controller2/ExportList', function (data) {
    //...
});

问题是,我没有得到任何下载,我不知道为什么。该方法被调用但没有下载。

这里有什么问题?

4

1 回答 1

6

您的控制器方法需要始终返回一个ActionResult. 所以该方法应该看起来更像

public ActionResult ExportList()
{
    var export = GenExport();

    CsvExport<LiveViewListe> csv = new CsvExport<LiveViewListe>(export);
    return new CsvResult(csv);
}

哪里CsvResult是继承自ActionResult并执行必要提示用户下载您的 Csv 结果的类。

例如,如果您真的需要这样做,Response.Write可能是:

public class CsvResult : ActionResult
{
    private CsvExport<LiveViewListe> data;
    public CsvResult (CsvExport<LiveViewListe> data)
    {
        this.data = data;
    }

    public override void ExecuteResult(ControllerContext context)
    {
        if (context == null)
        {
            throw new ArgumentNullException("context");
        }

        HttpResponseBase response = context.HttpContext.Response;

        response.ContentType = "text/csv";
        response.AddHeader("Content-Disposition", "attachment; filename=file.csv"));

        if (data!= null)
        {
            response.Write(data.Export());
        }
    }
}

CsvExport如果您的类具有以下Export方法,您还可以考虑使其更通用:

public class CsvResult<T> : ActionResult
{

    private CsvExport<T> data;
    public CsvResult (CsvExport<T> data)
    {
        this.data = data;
    }

    .... same ExecuteResult code
}

现在它支持您的任何 csv 下载,而不仅仅是LiveViewListe.

于 2013-07-22T09:49:25.300 回答