我在尝试创建下载链接时遇到问题,该链接将(1)原位生成CSV文件,(2)自动开始下载而不会被重定向到另一个页面(即AJAX请求)。
发生的情况如下:我没有看到任何JavaScript错误,处理程序CSVDownload也没有任何问题。但是,下载永远不会开始。出于某种原因,如果我只输入URL(..website ../ csvdownload),那么它确实使用相同的处理程序创建文件。知道为什么会这样吗?
非常感谢任何帮助!
HTML
<button id="mainReportDownload" type="button">
Download Report
</button>
AJAX请求
$('#mainReportDownload').on('click', function() {
$.ajax({
type: 'GET',
url: "/csvdownload",
beforeSend: function() {
notification('Creating report..','info',false)
}
});
});
的Python
def List2CSV(data):
csv = ""
for row in data:
for item in row:
csv = csv + item + ','
csv = csv[:-1] + '\n'
csv = csv[:-1]
return csv
class CSVDownload(webapp2.RequestHandler):
def get(self):
conn = rdbms.connect(instance=_INSTANCE_NAME, database='test')
cursor = conn.cursor()
cursor.execute('SELECT email FROM Test LIMIT 100')
testvalues = [[item for item in row] for row in cursor.fetchall()]
csv = List2CSV(testvalues)
self.response.headers['Content-Type'] = 'text/csv'
self.response.headers['Content-Disposition'] = 'attachment; filename=report.csv'
self.response.out.write(csv)
conn.close()
答案 0 :(得分:1)
你有相互矛盾的要求。当浏览器导航到发送回“附件”内容处置的URL时,会发生正常下载。但是你正在尝试使用Ajax,它不会导航,因此无法完成下载。 Ajax正在愉快地阅读内容,但之后只是将其丢弃,因为您没有定义成功处理程序,告诉它如何处理它。当然,即使您确实定义了该处理程序,出于明显的安全原因,Javascript也无法将文件保存到用户的计算机中。