如何在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 的请求拦截器插件。

相关推荐
茶憶6 小时前
UniApp 安卓端实现文件的生成,写入,获取文件大小以及压缩功能
android·javascript·vue.js·uni-app
2501_915921436 小时前
uni-app 的 iOS 打包与上架流程,多工具协作
android·ios·小程序·uni-app·cocoa·iphone·webview
weixin_4624462315 小时前
用 Go 快速搭建一个 Coze (扣子)API 流式回复模拟接口(Mock Server)
开发语言·golang·状态模式
iOS阿玮16 小时前
1V1 社交精准收割 3.6 亿!40 款马甲包 + 国内社交难度堪比史诗级!
uni-app·app·apple
脾气有点小暴20 小时前
uniapp开发APP 内嵌外部 HTTPS 链接的实现方案
vue.js·uni-app
简单点好不好1 天前
2025--简单点--python之状态模式
开发语言·python·状态模式
硕子鸽1 天前
UniApp + Dify 实战:详解 SSE 流式响应的解析与前端渲染
前端·uni-app·dify
2501_915918411 天前
iOS 项目中证书管理常见的协作问题
android·ios·小程序·https·uni-app·iphone·webview
Miketutu1 天前
[特殊字符] uni-app App 端实现文件上传功能(基于 xe-upload 插件)
前端·vue.js·uni-app