我在GSP中有一个ajax调用:
$.ajax({
url: '${request.contextPath + '/Ticket/passAll'}',
type: 'POST',
data: data,
success: function() {
alert("Success");
}
});
这是我的控制器动作中的代码块:
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()
我通过$.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');
}
});
在控制器中,我生成了纯文本字符串,但这样得到的文件没有扩展名,这是不可接受的。我该怎么做呢?谢谢。