---
title: "实现网页付费墙"
description: "了解如何使用 Adapty SDK 在 React Native 应用中实现网页付费墙。"
---

:::important
在开始之前，请确保您已[在看板中配置了网页付费墙](web-paywall)，并安装了 Adapty SDK 3.6.1 或更高版本。
:::

## 打开网页付费墙 \{#open-web-paywalls\}

如果您使用的是自行开发的付费墙，则需要通过 SDK 方法处理网页付费墙。`.openWebPaywall` 方法会：
1. 生成一个唯一 URL，使 Adapty 能够将向特定用户展示的付费墙与其被重定向到的网页关联起来。
2. 追踪用户何时返回应用，然后以短间隔请求 `.getProfile`，以确定用户画像的访问权限是否已更新。

这样，如果付款成功且访问权限已更新，订阅几乎会立即在应用中激活。

```typescript showLineNumbers title="React Native (TSX)"

try {
    await adapty.openWebPaywall(product);
} catch (error) {
    console.warn('Failed to open web paywall:', error);
}
```

:::note
`openWebPaywall` 方法有两个版本：
1. `openWebPaywall(product)`：通过付费墙生成 URL，并将产品数据附加到 URL 中。
2. `openWebPaywall(paywall)`：通过付费墙生成 URL，但不将产品数据附加到 URL 中。当 Adapty 付费墙中的产品与网页付费墙中的产品不同时使用此版本。
:::

#### 错误处理 \{#handle-errors\}

| 错误                                    | 描述                               | 建议操作                                          |
|-----------------------------------------|------------------------------------|---------------------------------------------------|
| AdaptyError.paywallWithoutPurchaseUrl   | 该付费墙未配置网页购买 URL         | 检查付费墙是否已在 Adapty 看板中正确配置          |
| AdaptyError.productWithoutPurchaseUrl   | 该产品没有网页购买 URL             | 在 Adapty 看板中验证产品配置                      |
| AdaptyError.failedOpeningWebPaywallUrl  | 无法在浏览器中打开 URL             | 检查设备设置或提供其他购买方式                    |
| AdaptyError.failedDecodingWebPaywallUrl | 无法正确编码 URL 中的参数          | 验证 URL 参数是否有效且格式正确                   |

## 在应用内浏览器中打开网页付费墙 \{#open-web-paywalls-in-an-in-app-browser\}

:::important
从 Adapty SDK v. 3.15 开始支持在应用内浏览器中打开网页付费墙。
:::

默认情况下，网页付费墙会在外部浏览器中打开。

为了提供流畅的用户体验，您可以在应用内浏览器中打开网页付费墙。这会在您的应用内显示网页购买页面，让用户无需切换应用即可完成交易。

要启用此功能，请将 `WebPresentation.BrowserInApp` 作为第二个参数传递给 `openWebPaywall`：

```typescript showLineNumbers title="React Native (TSX)"

try {
    await adapty.openWebPaywall(
        product,
        WebPresentation.BrowserInApp, // default – WebPresentation.BrowserOutApp
    );
} catch (error) {
    console.warn('Failed to open web paywall:', error);
}

```