记录nfc.listenNFCStatus多次刷卡后会重复调用接口

当你使用nfc.listenNFCStatus在UniApp中监听NFC(Near Field Communication)状态时,可能会出现多次刷卡后接口被重复调用的情况。这通常发生是因为在多次刷卡后,NFC状态变化多次触发了监听事件。要解决这个问题,你可以使用一些技巧和策略来确保接口只在需要的时候被调用一次。

以下是一些可能的解决方法:

1. 防止重复触发:

在事件处理程序中,可以设置一个标志来标记接口是否已经被调用。如果接口已经被调用,那么在下一次NFC状态变化时,你可以检查这个标志并避免重复调用接口。这可以通过布尔变量或其他方式来实现

let isNFCInterfaceCalled = false;

nfc.listenNFCStatus({
  success: function(res) {
    if (!isNFCInterfaceCalled) {
      // 调用接口
      isNFCInterfaceCalled = true;
    }
  },
  fail: function(err) {
    console.log('NFC status listen failed: ' + JSON.stringify(err));
  }
});

2. 延时处理

在接口调用后,可以添加一个延时,以确保在下一个NFC状态变化事件之前不会再次调用接口。这可以通过setTimeout函数来实现。

let isNFCInterfaceCalled = false;

nfc.listenNFCStatus({
  success: function(res) {
    if (!isNFCInterfaceCalled) {
      // 调用接口
      isNFCInterfaceCalled = true;

      // 添加延时,避免重复调用
      setTimeout(function() {
        isNFCInterfaceCalled = false;
      }, 1000); // 设置延时时间,单位毫秒
    }
  },
  fail: function(err) {
    console.log('NFC status listen failed: ' + JSON.stringify(err));
  }
});

3. 使用计数器:

你可以使用一个计数器来跟踪调用接口的次数,并在达到一定的次数后停止监听NFC状态,以避免继续触发事件。

let callCount = 0;

nfc.listenNFCStatus({
  success: function(res) {
    if (callCount < 1) {
      // 调用接口
      callCount++;

      if (callCount >= 5) {
        // 停止监听NFC状态
        nfc.stopListenNFCStatus();
      }
    }
  },
  fail: function(err) {
    console.log('NFC status listen failed: ' + JSON.stringify(err));
  }
});

根据你的具体需求和应用场景,你可以选择其中一种或多种方法来解决重复调用接口的问题。确保你的代码适用于你的UniApp版本和NFC设备。

依据接口调用记录检查接口重复调用有多种方法,以下是不同场景下的具体实现: ### NFC 接口重复调用检查 在 NFC 接口调用场景中,可使用布尔变量作为标志来检查接口是否已被调用。当首次调用接口时,将标志设置为 `true`,后续调用时检查该标志,若为 `true` 则不再重复调用接口。示例代码如下: ```javascript let isNFCInterfaceCalled = false; nfc.listenNFCStatus({ success: function(res) { if (!isNFCInterfaceCalled) { // 调用接口 isNFCInterfaceCalled = true; } }, fail: function(err) { console.log('NFC status listen failed: ' + JSON.stringify(err)); } }); ``` 此方法通过 `isNFCInterfaceCalled` 布尔变量标记接口调用状态,在事件处理程序中进行检查,避免了 NFC 接口重复调用 [^1]。 ### 表单验证接口重复调用检查 在表单验证调用接口的场景中,可根据业务逻辑在合适的时机进行接口调用判断。示例代码如下: ```javascript export default { data() { let validatePasscode = (rule, value, callback) => { console.log(this.edit); if (!this.edit) { this.$api .isaccessDictvalidate({ query: { code: this.formData.code, }, }) .then((res) => { console.log(res); if (res.code == 1) { callback(new Error("已经存在,不能重复")); } else { callback(); } }); } else { callback(); } }; return { rules: { appId: [ { required: true, message: "请选择关联应用", trigger: "change" }, { required: true, trigger: "change", validator: validatePasscode }, ], }, }; }, }; ``` 该方法在表单验证的自定义验证函数 `validatePasscode` 中,根据 `this.edit` 的值决定是否调用接口,避免不必要的重复调用 [^2]。 ### 页面、接口重复提交检查 对于页面或接口重复提交的情况,可借助 Redis 设置有效期来解决。示例代码如下: ```java @Transactional public void checkRepeat(String name, String userId) { String check_repeat = "repeat::%s::%s"; String key = String.format(check_repeat, name, userId); boolean bool = redisTemplate.opsForValue().setIfAbsent(key, "1"); if (bool) { redisTemplate.expire(key, 5, TimeUnit.SECONDS); } else { throw new RepeatException(); } } ``` 此方法利用 Redis 的 `setIfAbsent` 方法尝试设置一个带有特定有效期的键,如果设置成功则允许接口调用,否则抛出异常,防止重复提交 [^3]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值