你的位置:首页 > Java教程

[Java教程]复制粘贴出来的悲剧


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

网上有这么一个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); }