4
@RequestMapping( method = RequestMethod.POST, value = DataController.RESOURCE_PATH + "/file", headers = "content-type=application/json" )
@ResponseBody
public void export( @RequestBody JSONObject json, HttpServletResponse response ) throws IOException
{
    String myString = "Hello";
}

该字符串在Controller. 我想要的是向用户发送回一个窗口,他可以在其中保存一个包含myString.

$.ajax({
    type: "POST",
    url: url,
    data: JSON.stringify(createJSON()),
    contentType: "application/json",
    success: function(response)
    {
        console.log("Exported JSON: " + JSON.stringify(createJSON()));
        console.log(response);
    },
    error: function()
    {
        console.log(arguments);
        alert("Export process failed.");
    }
});

它显然在当前状态下不起作用,我现在被卡住了。

4

3 回答 3

13

这是一个示例:

@RequestMapping( method = RequestMethod.POST, 
    value = DataController.RESOURCE_PATH + "/file", 
    headers = "content-type=application/json" )
public void export( @RequestBody JSONObject json, HttpServletResponse response ) 
    throws IOException {
    String myString = "Hello";
    response.setContentType("text/plain");
    response.setHeader("Content-Disposition","attachment;filename=myFile.txt");
    ServletOutputStream out = response.getOutputStream();
    out.println(myString);
    out.flush();
    out.close();
}

PS:不要忘记在你的 url 中放一些随机的东西(例如作为参数),以确保你的浏览器不会缓存文本文件。

于 2013-07-17T18:08:00.730 回答
0

要返回文件,您需要将MediaType.APPLICATION_OCTET_STREAM用作响应类型。

于 2013-07-17T18:00:43.210 回答
0

我建议使用filesaver.js

然后您的解决方案将如下所示:

var text = JSON.stringify(createJSON());  
var blob = new Blob([text], {type: "text/plain; charset=utf-8"});                           
saveAs(blob, "myfile.txt");  
于 2016-06-16T05:49:31.577 回答