后端说:只是你不懂怎么用 headers!

(点击上方公众号,可快速关注)


来源:esbook

https://www.jianshu.com/p/86c92387351f


事情是这样的,上一个项目我们的后端提供的接口,一次性返回了所有数据给我,分页功能是前端自己完成的。

那么这次来的新项目,换了个后端,写了另外的接口,我做项目的时候,还是用的之前的前端分页组件,但是测试说前端的分页没有做?

于是乎,我就问后端,你返回给我的数据里面没有统计总数啊不能返回给我么?

640?wx_fmt=png

这样的回答没毛病,毕竟全部一次性返回给我,sql 查询是挺费事的,不过这只不不过是一个 demo 系统,演示给客户看的,再说目前会有多少条数据,即便是百万条数据,mysql 的查询性能我想也不会很差,毕竟您不要做一下 sql 优化吗?

640?wx_fmt=png

果然是高手,把分页数据 存在 response.header 里面了,顺便多说一句,我们这个是前后端分离的项目,因为存在 cros 跨域,所以,我这边获取 response.headers 只能获取以下的数据

640?wx_fmt=png

并不能完全获取后端自定义的 response header 的所有数据,科普了一下原来是这样的

640?wx_fmt=png

我问后端,你设置了吗,后端说不用设置啊,说另外一个同事可以取(据我说知另外一个同事使用的 swagger)你用 swagger 同一个端口、域名,存在跨域吗,我想问你?你还好意思让我用 swagger 测试你的接口,那 tm 当然不会存在跨域问题,当然可以在 response.headers 里面得到你的分页数据

640?wx_fmt=png

你返回给我的是这样的数据,让我猜想一下,可能是用了统一的方法,你不好去改后端返回的数据,或则还是你比较懒。就 是不想把分页数据,通过正常 respone.text 传给我,还是你故意显示你的技术牛逼!存在 header 里面?

640?wx_fmt=png

呵呵,此时后端嘲讽我 『只是你不懂怎么用 header』

640?wx_fmt=png

问我是 js 么?我一个攻城狮,发送 ajax 请求,你问我是 js 么,还要教我,不好意思,这点尊严还是有的,既然你这么懂 header,那么我前端传递参,也把当前的页码,page 参数(后端需要的参数),存在 header 里面

640?wx_fmt=png

其实本来应该放在 query string 里面的,你既然喜欢在 response.headers 存总页码,那就别怨我在

request.headers 里面给你传递 page,毕竟我不懂 header~~~

顺便提一下,我存在 headers里面了,我测试分页,发现不管我点击哪个页面,后端返回的总是第一页的数据,那么我敢断定,后端取参数,肯定不是从 headers 里面取的 page

本来easy 的事情,你非要搞这么复杂,何必呢,跟我显摆什么呢。。。

=======================================================

今天又更新了,我们继续看热闹


640?wx_fmt=png

说到这里我就笑了,该后端说,他的 response.header 存放分页 数据 是 response 的一部分。是正常操作

我前端 用 request.headers 传递 页面 就是不符合 restful 规范了?

首先他说的这个 restful 规范,我就笑了,人家 restful 是一种风格而已,

退一步说,你后端传 response.headers 就可以,我前端 就不行了,不符合规范了?我看是你取不到页码了吧!!!

导致你的 query 语句一直取的默认为第一页的数据,辣鸡!

640?wx_fmt=png

因为上个项目 是另外一个后端,做的也是一个 demo,一次性返回20多条数据给我,前端自己做的分页

跟这个人合作,第一次,我就问能不能一次性全部给我,不行就拉倒。现在借着这个话题跟我扯性能问题

请我一下现在做的这个 demo 就10几条数据,你跟我谈什么性能?你确定你真的懂 sql 性能,

说我态度有问题,你接口文档上有跟我说分页写在了reponse.header 里面?你接口文档上面有说要传递 page 参数么?

swagger 上面就 tm 一个 请求,一个 type,又告诉前端传递正确参数么?你返回的 response.headers 里面的分页数据又在哪里?

640?wx_fmt=png640?wx_fmt=png

死猪不怕开水烫,文章一开始我就跟他说了如果后端设置了自定义的 response.headers,服务器端要配置一下,

否则前端是拿不到的,还不行,你现在怎么知道去设置了?你刚才不是 振振有词说 为什么别人可以你不可以吗?

那你 tm 如果不按照我说的去配置,你 tm 取给我看看?

你自己说的话,是不是啪啪啪打脸?

640?wx_fmt=png

说了这么多,你就是不愿意把分页放在 response .text 里面是吧,坚持放 header 里面是吧

640?wx_fmt=png

还什么基于 yii 分页序列化,分页序列化跟你返回的数据格式有毛关系,你 tm 说白了,就是不想改返回的数据格式

你认为现在就这么处理分页是把,还是把分页数据存 headers 里面对把,

得了,那老子前端就给你传 request.headers里面 告诉你 page 就在那,你爱取不取,我 tm 就是有情绪了,咋啦,

你不是说我不懂 headers 么,还 tm 要教我 js?呵呵。。。。。



【关于投稿】


如果大家有原创好文投稿,请直接给公号发送留言。


① 留言格式:
【投稿】+《 文章标题》+ 文章链接

② 示例:
【投稿】《不要自称是程序员,我十多年的 IT 职场总结》:http://blog.jobbole.com/94148/

③ 最后请附上您的个人简介哈~





觉得本文对你有帮助?请分享给更多人

关注「前端大全」,提升前端技能

640?wx_fmt=png

640?wx_fmt=jpeg

### 回答1: 我不会JAVA后端代码,但是可以提供一些建议:1. 首先,您需要定义一个Servlet,用于接受前端的请求并处理它们。2. 使用Java的I/O流处理请求,以获取文件,并将其发送到前端。3. 最后,您可以使用Java的HttpServletResponse对象来将文件发送到前端。 ### 回答2: 下面是一个示例的Java后端代码,实现了根据前端请求进行文件下载的功能: ```java import org.springframework.core.io.Resource; import org.springframework.core.io.UrlResource; import org.springframework.http.HttpHeaders; import org.springframework.http.MediaType; import org.springframework.http.ResponseEntity; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import javax.servlet.http.HttpServletRequest; import java.io.File; import java.io.IOException; import java.nio.file.Path; import java.nio.file.Paths; @RestController @RequestMapping("/api/download") public class FileDownloadController { @GetMapping("/{filename}") public ResponseEntity<Resource> downloadFile(@PathVariable String filename, HttpServletRequest request) throws IOException { // 获取要下载的文件路径 String filePath = "/path/to/files/" + filename; Path path = Paths.get(filePath); Resource resource = new UrlResource(path.toUri()); // 根据文件的MIME类型设置响应头 String contentType = request.getServletContext().getMimeType(resource.getFile().getAbsolutePath()); contentType = contentType == null ? "application/octet-stream" : contentType; // 构建并返回响应实体 return ResponseEntity.ok() .contentType(MediaType.parseMediaType(contentType)) .header(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=\"" + resource.getFilename() + "\"") .body(resource); } } ``` 在上述代码中,我们定义了一个名为`downloadFile`的方法,用于处理前端的下载文件请求。该方法使用`@GetMapping`注解来映射请求路径,并通过`@PathVarliable`注解来获取请求中的文件名。 在方法体内,我们首先根据文件名构建文件的绝对路径,并将其封装为`Resource`对象。然后,我们根据文件的MIME类型设置响应头中的Content-Type,并通过`ResponseEntity.ok()`来构建响应实体。 最后,我们设置响应实体的Content-Disposition头,将文件名作为附件提供下载。最后,返回包含文件内容的`Resource`对象作为响应体,完成文件下载过程。 请注意,你需要根据自己的实际情况修改代码中的文件路径和文件类型相关的代码。 ### 回答3: 以下是一个简单的JAVA后端代码示例,用于接受前端请求并通过IO流将文件下载至前端。 ```java @RestController public class FileController { @GetMapping("/download") public void downloadFile(HttpServletRequest request, HttpServletResponse response) { // 获取要下载的文件路径(可以根据前端请求参数或其他方式获得) String filePath = "/path/to/file.ext"; File file = new File(filePath); if (file.exists()) { try { // 设置响应头,指定文件下载方式 response.setContentType("application/octet-stream"); response.setHeader("Content-Disposition", "attachment; filename=" + file.getName()); // 创建输入流读取文件数据 FileInputStream inputStream = new FileInputStream(file); // 创建输出流将文件数据入 response ServletOutputStream outputStream = response.getOutputStream(); byte[] buffer = new byte[1024]; int len; while ((len = inputStream.read(buffer)) != -1) { outputStream.write(buffer, 0, len); } // 关闭流 outputStream.flush(); inputStream.close(); outputStream.close(); } catch (IOException e) { e.printStackTrace(); } } else { // 文件不存在的处理逻辑 } } } ``` 这个示例中,我们使用`@GetMapping("/download")`注解将方法映射为接收前端请求的路径。根据实际情况,你可以根据实际需求添加其他的请求映射注解(如`@PostMapping`)。 在方法中,我们首先获取要下载的文件路径,然后创建一个`File`对象。如果文件存在,我们设置响应头,指定文件下载方式,并创建输入流和输出流。 通过读取输入流的数据,并将其入输出流中,我们实现了将文件数据发送给前端进行下载的功能。最后,记得关闭流。 当然,在实际开发中,你可能还需要处理异常、验证请求、设置文件名等其他逻辑。这个示例只是提供了一种简单的实现思路。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值