从Ajax下载文件(有点)

dra*_*ago 4 ajax jquery grails download

我在我的GSP中有这个ajax调用:

$.ajax({
    url: '${request.contextPath + '/Ticket/passAll'}',
    type: 'POST',
    data: data,
    success: function() {
        alert("Success");
    }
});
Run Code Online (Sandbox Code Playgroud)

这是我的控制器操作的代码块:

response.setHeader("Content-disposition", "attachment; filename=sample.csv")
response.contentType = "application/vnd.ms-excel"

def outs = response.outputStream
def cols = [:]

tickets.each() {
    outs << it.ticketNo + ";" + it.subject
    outs << "\n"
}

outs.flush()
outs.close()
Run Code Online (Sandbox Code Playgroud)

我通过$ .Ajax方法从视图传递的数据中获取票证列表.比我将数据格式化为CSV并且我想将该数据导出为CSV文件但没有任何反应.数据被发送到客户端,但没有文件可供下载,因为内容配置不是很好.我错过了什么?我试过做类似的事情:

$.ajax({
    url: '${request.contextPath + '/Ticket/passAll'}',
    type: 'POST',
    data: aoData,
    dataType: 'text',
    success: function(result) {
        var uri = 'data:application/csv;charset=UTF-8,' + encodeURIComponent(result);
        window.open(uri, 'tiketi.csv');
    }
});
Run Code Online (Sandbox Code Playgroud)

并在控制器中我生成纯字符串,但这样我得到一个没有扩展名的文件是不可接受的.

我怎样才能做到这一点?谢谢.

Jam*_*eeh 14

你不需要通过ajax来做.该页面不会重定向文件下载.


luc*_*e84 6

我猜url属性应该固定,因为你的引号是碰撞的.

试试:

$.ajax({
    url: "${request.contextPath}/Ticket/passAll",
    type: 'POST',
    data: aoData,
    dataType: 'text',
    success: function(result) {
        var uri = 'data:application/csv;charset=UTF-8,' + encodeURIComponent(result);
        window.open(uri, 'tiketi.csv');
    }
});
Run Code Online (Sandbox Code Playgroud)

  • 为什么我的文件名不是 `tiketi.csv` 而是一个随机名称? (2认同)

Mar*_* L. 6

据我所知,不可能通过AJAX触发文件下载.相反,你可以做这样的事情(例如使用jQuery):

function downloadComplete(){ hideSpinner();}
function downloadStart(){ showSpinner();}

function download(){
    downloadStart()
    var urlParams = data // or e.g. $(form).serialize() 
    var downloadUrl = "${request.contextPath}/Ticket/passAll?" + urlParams 
    $("#download-iframe").remove()
    $('<iframe style="display:none" id="download-iframe" src="' + downloadUrl + '" onreadystatechange="downloadComplete()" onload="downloadComplete()">').appendTo('body');
}
Run Code Online (Sandbox Code Playgroud)

您可能遇到问题,因为它是GET请求:"安全性"或参数太多.但在正常情况下应该没问题.