003_接口的幂等性

2020-10-09   16 次阅读


1.1 概念

  1. 效果:系统对某接口的多次请求,都应该返回同样的结果!(网络访问失败的场景除外)
  2. 目的:避免因为各种原因,重复请求导致的业务重复处理

1.2 重复请求场景

  1. 客户端第一次请求后,网络异常导致收到请求执行逻辑但是没有返回给客户端,客户端的重新发起请求
  2. 客户端迅速点击按钮提交,导致同一逻辑被多次发送到服务器

1.3 实现方式

  1. 客户端做某一请求的时候带上识别参数标识,服务端对此标识进行识别,重复请求则重复返回第一次的结果即可。比如添加请求的表单里,在打开添加表单页面的时候,就生成一个AddId标识,这个AddId跟着表单一起提交到后台接口。
  2. 后台接口根据这个AddId,服务端就可以进行缓存标记并进行过滤,缓存值可以是AddId作为缓存key,返回内容作为缓存Value,这样即使添加按钮被多次点下也可以识别出来。
  3. 只有在保存成功并且清空表单之后,才变更这个AddId标识,从而实现新数据的表单提交

Q.E.D.

知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议