幂等性

1. 生成key的方式

记得保证redis生成的key和删除的key是成功的(看返回值)

1)允许表单跳转

这种情况比较容易,比如在列表中添加一条记录,可以在列表页面生成一个key,放到redis中,同时在添加页面时带着这个key。等到提交时,把key也提交,后台根据key与redis中进行比较,有的话保存,保存成功就删除这个key。而没有时就直接放弃保存(重复提交)

2)不允许表单跳转

可以将提交的表单进行hash运算,生成一个key,设置一个有效时间,用来规定该时间段内提交的都是重复提交。如果在规定时间内再次提交相同的表单数据,那么hash值也是相同的,这样可以给前台提示是否要重复提交(可能用户就想重复提交,得给他这个机会)。hash值的相同来判断他是否为重复提交

2. sql索引

有些数据有业务上的唯一性,可以采用这种方法。
比如,一个活动只允许用户注册一次,注册的方式是使用手机号的方式。那么可以通过活动ID+手机号的方式创建唯一索引。插入数据时通过mysql的唯一索引的唯一性来保证数据不会重复提交
幂等性的实现

3.不知道有没有类似语句或触发器之类的
通过类似sql语句,有数据啥也不干,没有数据才进行插入

相关文章:

  • 2022-12-23
  • 2021-09-17
  • 2021-12-08
  • 2020-03-26
  • 2021-12-24
  • 2022-03-07
  • 2022-01-17
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2021-11-06
  • 2021-05-21
  • 2022-12-23
  • 2021-09-21
  • 2022-12-23
相关资源
相似解决方案