跳过主要内容
简体中文

如何使用__CAPGO_KEEP_0__的通道进行功能标志和A/B测试

了解如何使用Capgo的通道进行功能标志和A/B测试,通过自行分配用户或使用您的后端

马丁·多纳迪厄

马丁·多纳迪厄

内容营销

如何使用__CAPGO_KEEP_0__的通道进行功能标志和A/B测试

如何使用__CAPGO_KEEP_0__的通道进行功能标志和A/B测试

Capgo的通道系统提供了一种灵活的方式来分段用户并控制功能访问。虽然Capgo没有内置的计划管理或A/B测试功能,但您可以通过管理通道分配来实现这些功能。

了解通道

在Capgo中,通道允许您:

  • 针对不同用户群组使用不同的功能
  • 通过将用户分配到不同的频道来运行A/B测试
  • 逐渐推出新功能
  • 创建beta测试计划

频道分配方法

这是更安全的方法。它涉及:

  1. 从更新器获取设备ID
  2. 将其发送到您的后端
  3. 您的后端调用Capgo API来分配设备

以下是如何实现它:

import { CapacitorUpdater } from '@capgo/capacitor-updater'

// Get device ID
const getDeviceId = async () => {
  const { deviceId } = await CapacitorUpdater.getDeviceId()
  return deviceId
}

// Send device ID to your backend
const assignToChannel = async (channel: string) => {
  const deviceId = await getDeviceId()
  // Your backend will call Capgo API to assign the device
  await yourBackend.assignDeviceToChannel(deviceId, channel)
}

后端实现

您的后端需要:

  1. 从 Capgo 控制台获取一个 API 密钥
  2. 调用 Capgo API 将设备分配到一个频道

获取您的 API 密钥:

  1. 登录您的 Capgo 控制台
  2. 转到设置 > API 密钥
  3. 点击“生成新密钥”
  4. 选择 all 模式来管理设备和频道
  5. 复制生成的密钥并在您的后端环境变量中安全存储
    • 密钥将是一个 32 个字符的十六进制字符串
    • 它是一个秘密密钥,绝不应该在客户端 code 中暴露

Node.js 的一个例子:

import axios from 'axios'

const CAPGO_API_KEY = 'your_api_key'
const CAPGO_API_URL = 'https://api.capgo.app'

async function assignDeviceToChannel(deviceId: string, channel: string) {
  try {
    const response = await axios.post(
      `${CAPGO_API_URL}/device`,
      {
        app_id: 'YOUR_APP_ID',
        device_id: deviceId,
        channel: channel
      },
      {
        headers: {
          'authorization': CAPGO_API_KEY,
          'Content-Type': 'application/json'
        }
      }
    )
    return response.data
  } catch (error) {
    console.error('Failed to assign device to channel:', error)
    throw error
  }
}

后端也应该:

  • 验证用户的权限
  • 记录所有频道分配
  • 处理速率限制
  • 为失败的分配实现重试逻辑

2. 自我分配(不安全)

该方法允许设备直接将自己分配到一个频道。它适用于测试,但在生产环境中不安全:

import { CapacitorUpdater } from '@capgo/capacitor-updater'

// Assign device to channel
const assignToChannel = async (channel: string) => {
  await CapacitorUpdater.setChannel(channel)
}

// Get current channel
const getCurrentChannel = async () => {
  const { channel } = await CapacitorUpdater.getChannel()
  return channel
}

在 Capgo 控制台中启用此功能之前,用户才能自行分配到频道:

  1. 在您的 Capgo 控制台中,前往频道部分
  2. 单击要管理的频道名称
  3. 在频道设置中,启用“允许设备自行关联”
  4. 保存更改

如果此设置为 false,任何尝试通过 setChannel 将会失败。

功能标志的实现

使用通道来控制功能访问:

const isFeatureEnabled = async (feature: string) => {
  // Example: Check if user is in beta channel
  const channel = await getCurrentChannel()
  return channel === 'beta'
}

A/B 测试实现

通过将用户分配到不同的通道来运行 A/B 测试:

const assignToABTest = async (userId: string) => {
  // Use consistent hashing to assign users
  const hash = await hashUserId(userId)
  const variant = hash % 2 === 0 ? 'variant-a' : 'variant-b'
  
  await assignToChannel(variant)
  return variant
}

最佳实践

  1. 在生产环境中,始终使用后端分配方法一致的分配
  2. : 使用用户 ID 或其他稳定的标识符来实现一致的通道分配__CAPGO_KEEP_0__
  3. 监控: 为每个渠道跟踪功能使用情况和性能指标
  4. 渐进式发布: 先从小规模用户开始,然后逐渐扩大
  5. 清晰的文档: 记录您的渠道策略和目的

结论

通过利用Capgo的渠道系统,您可以创建更具个人化的应用体验并进行A/B测试。对于生产环境,始终优先使用后端分配方法以获得更好的安全性和控制。

有关渠道管理的更多详细信息,请参阅我们的 渠道文档.

Capacitor 应用程序的实时更新

当 web 层面的 bug 活跃时,通过 Capgo 将修复推送给用户,而不是等待几天的 app store 审批。用户在后台接收更新,而原生变化仍然在正常的审批路径中。

立即开始

最新博客文章

Capgo 为您提供了创建真正专业的移动应用所需的最佳见解。