uni-app 因oaid问题多次被打回,按现有解决方案仍无效,最新版本已替换index,vue2

发布于 1周前 作者 zlyuanteng 来自 Uni-App

uni-app 因oaid问题多次被打回,按现有解决方案仍无效,最新版本已替换index,vue2

操作步骤:

1

预期结果:

1

实际结果:

1

bug描述:

获取oaid频繁

2 回复

不要占用公众资源,发一些语焉不详的帖子。


在处理 uni-app 因 OAID(Open Anonymous Device Identifier,开放匿名设备标识符)问题被多次驳回的情况时,通常是因为应用获取或使用 OAID 的方式不符合相关平台(如华为、小米等)的政策或隐私要求。以下是一个针对如何在 uni-app 中安全合规地获取 OAID 的代码示例,这里假设你已经有了相关平台的 SDK 并进行了配置。

步骤一:集成第三方 SDK

首先,确保你已经根据平台文档集成了获取 OAID 的 SDK。以华为为例,你可能需要在 manifest.json 中添加华为 SDK 的配置,并在项目中引入华为 SDK 的相关代码。

步骤二:创建获取 OAID 的方法

utils 目录下创建一个 getOAID.js 文件,用于封装获取 OAID 的逻辑:

// utils/getOAID.js
export function getOAID() {
    return new Promise((resolve, reject) => {
        // 假设你使用的是华为的 SDK
        if (window.HMSAds) {
            window.HMSAds.getAdvertisingIdInfo((info) => {
                if (info && info.isLimitAdTrackingEnabled === false) {
                    resolve(info.id); // 获取到的 OAID
                } else {
                    reject('OAID 获取失败或用户限制了广告追踪');
                }
            }, (error) => {
                reject('获取 OAID 时发生错误: ' + error);
            });
        } else {
            reject('HMSAds SDK 未加载');
        }
    });
}

步骤三:在 Vue 组件中调用获取 OAID 的方法

在你的 Vue 组件中,你可以这样调用获取 OAID 的方法:

<template>
  <div>
    <!-- 你的模板内容 -->
  </div>
</template>

<script>
import { getOAID } from '@/utils/getOAID';

export default {
  mounted() {
    getOAID().then((oaid) => {
      console.log('OAID:', oaid);
      // 在这里处理 OAID,比如发送到服务器
    }).catch((error) => {
      console.error('获取 OAID 失败:', error);
    });
  }
}
</script>

注意事项

  1. 合规性:确保你的应用获取和使用 OAID 的方式符合所有相关平台的隐私政策和法规要求。
  2. 错误处理:在实际应用中,增加更多的错误处理和用户反馈机制,以提高用户体验。
  3. 测试:在多个设备和平台上测试你的实现,确保它在所有目标环境中都能正常工作。

通过上述步骤,你应该能够在 uni-app 中合规地获取 OAID,并解决因 OAID 问题导致的应用驳回问题。

回到顶部