复制粘贴出来的悲剧----spring实现文件下载和HttpStatus.CREATED

今天真是被自己的懒惰和复制粘贴给坑惨了...

网上有这么一个spring下载文件的最佳实践:

@RequestMapping("download")  
public ResponseEntity<byte[]> download() throws IOException {  
    HttpHeaders headers = new HttpHeaders();  
    headers.setContentType(MediaType.APPLICATION_OCTET_STREAM);  
    headers.setContentDispositionFormData("attachment", "xxx.txt");  
    return new ResponseEntity<byte[]>(FileUtils.readFileToByteArray(getDictionaryFile()),  
                                      headers, HttpStatus.CREATED);  
}

可以看到返回状态给的是HttpStatus.CREATED(201),这个当时想当然的认为既然是下载文件,肯定是新创建,所以create也没什么,也就没进一步仔细查询一下201状态码的意义.然后呢这段代码实际上在谷歌和火狐上执行是一点问题没有的,所以一直以来就这么复制粘贴复制再粘贴...直到今天发现这段代码实际上在ie上是有问题的.

然后折腾了一下午加上一晚上,一直以为是MediaType的问题,换了n种方式依然未果.因为我知道这里返回HttpStatus.OK也是可以,所以只是麻木的各种尝试把它换成OK(200),结果在ie下真就好了.这才想起来仔细查询一下HttpStatus.CREATED(201)的含义,大体含义如下:

服务器已经创建了文档,Location头给出了它的URL。

源码中给的参考地址已经无法访问,所以只能简单的百度一下http状态码,上面只是其中的一种解释,但是大体都是说服务器已经创建了文档,这个实际上和下载文件没半点关系..

所以正确的写法应该是:

@RequestMapping("download")  
public ResponseEntity<byte[]> download() throws IOException {  
    HttpHeaders headers = new HttpHeaders();  
    headers.setContentType(MediaType.APPLICATION_OCTET_STREAM);  
    headers.setContentDispositionFormData("attachment", "xxx.txt");  
    return new ResponseEntity<byte[]>(FileUtils.readFileToByteArray(getDictionaryFile()),  
                                      headers, HttpStatus.OK);  
}

 

posted on 2016-03-14 21:27  蓝萝卜blu  阅读(4133)  评论(0编辑  收藏  举报

导航