如何在yii2的uniapp项目中处理提交重复问题?

文章目录

  • 前言
  • [一、前端防重复提交(UniApp 端)](#一、前端防重复提交(UniApp 端))
  • [二、后端防重复提交(Yii2 端)](#二、后端防重复提交(Yii2 端))
  • 总结

前言

在 Yii2 的 UniApp 项目中处理提交重复问题,需结合前端和后端的双重防护机制。以下是具体方案:


一、前端防重复提交(UniApp 端)

UniApp 通过请求拦截器实现全局防重复提交:

javascript 复制代码
// 在 main.js 或 uni-app 的拦截器配置中
uni.addInterceptor('request', {
  invoke(args) {
    // 请求前禁用按钮
    uni.showLoading({ title: '提交中...' });
    args.header['Idempotency-Key'] = generateIdempotencyKey(); // 生成唯一标识
  },
  success(res) {
    // 请求成功后恢复按钮
    uni.hideLoading();
  },
  fail(err) {
    // 请求失败后恢复按钮
    uni.hideLoading();
  }
});

function generateIdempotencyKey() {
  return 'idempotency_' + Date.now() + '_' + Math.random().toString(36).substr(2, 9);
}

二、后端防重复提交(Yii2 端)

在 Yii2 控制器中添加幂等性校验:

php 复制代码
public function actionCreate()
{
    $key = Yii::$app->request->getHeaders()->get('Idempotency-Key');
    if ($key && Yii::$app->cache->exists($key)) {
        return $this->asJson(['error' => '重复提交']);
    }

    $model = new Campus();
    if ($model->load(Yii::$app->request->post()) && $model->save()) {
        Yii::$app->cache->set($key, true, 300); // 缓存5分钟
        return $this->redirect(['view', 'id' => $model->id]);
    } else {
        return $this->render('create', ['model' => $model]);
    }
}

总结

关键说明:

‌前端拦截器‌:通过 Idempotency-Key 头传递唯一标识,防止用户重复点击提交按钮。

‌后端幂等性校验‌:使用缓存存储 Idempotency-Key,确保同一标识在一定时间内只能处理一次。

‌用户体验‌:提交时显示加载提示,防止用户误操作。

注意事项:

Idempotency-Key 生成规则需保证唯一性,建议结合时间戳和随机数。

缓存时间(如300秒)需根据业务场景调整。

需在 UniApp 项目中安装 uni-app 的请求拦截器插件。

相关推荐
小王不爱笑13220 分钟前
序列化和反序列化
状态模式
程序员Sunday3 小时前
说点不一样的。GPT-5.3 与 Claude Opus 4.6 同时炸场,前端变天了?
前端·gpt·状态模式
前端不太难4 小时前
HarmonyOS 游戏项目,从 Demo 到可上线要跨过哪些坑
游戏·状态模式·harmonyos
2501_916008896 小时前
深入解析iOS机审4.3原理与混淆实战方法
android·java·开发语言·ios·小程序·uni-app·iphone
QT.qtqtqtqtqt7 小时前
uni-app小程序前端开发笔记(更新中)
前端·笔记·小程序·uni-app
万物得其道者成8 小时前
阿里云 H5 一键登录接入实战:前后端完整实现
阿里云·云计算·状态模式
前端不太难9 小时前
在 HarmonyOS 上,游戏状态该怎么“死而复生”
游戏·状态模式·harmonyos
喵喵虫17 小时前
uniapp修改封装组件失败 styleIsolation
uni-app
木斯佳19 小时前
前端八股文面经大全:26届秋招滴滴校招前端一面面经-事件循环题解析
前端·状态模式
hepingfly19 小时前
不再单打独斗!用 Agent Teams 让 7 个 Claude 同时帮你开发
状态模式