Flutter用户隐私同意管理插件usercentrics_sdk的使用

发布于 1周前 作者 gougou168 来自 Flutter

Flutter用户隐私同意管理插件usercentrics_sdk的使用

欢迎使用Usercentrics

您现在距离在您的应用程序中实现“隐私”核心功能更近了一步。我们很高兴您决定将此作为优先事项。我们在这里帮助您与用户建立信任。

Usercentrics Apps SDK

Usercentrics Apps SDK 是一个为移动应用、移动游戏和电视应用提供的本地同意管理平台解决方案,它能够收集、记录和管理用户的隐私选择,以确保全球法律合规性。

Usercentrics UI

要求

  • Dart 2.17.1 或更高版本
  • Flutter 1.20.0 或更高版本
  • Android 4.1(API 16)或更高版本,Kotlin 1.5 或更高版本
  • iOS 11 或更高版本
Android Kotlin 版本低于 1.5

如果您的 Kotlin 版本不兼容,可能会看到以下错误:

e: Incompatible classes were found in dependencies. Remove them from the classpath or use '-Xskip-metadata-version-check' to suppress errors

解决方法是增加 android/build.gradle 文件中的 Kotlin 版本,例如:1.5.31Kotlin Version

Android 版本低于 5.0 (API 21)

如果您支持 Android 版本低于 5.0 (API 21) 并且没有启用多 Dex 支持,可能会看到以下错误:

D8: Cannot fit requested classes in a single dex file (# methods: 66055 > 65536)

您可以将最低版本设置为 5.0 (API 21),或者启用多 Dex 支持:

implementation "androidx.multidex:multidex:2.0.1"
multiDexEnabled true
android:name="androidx.multidex.MultiDexApplication"
iOS 版本低于 11

如果您有 iOS 目标版本低于 11 或者没有任何版本(默认为版本 9),可能会看到以下错误:

[!] Automatically assigning platform `iOS` with version `9.0` on target `Runner` because no platform was specified. Please specify a platform for this target in your Podfile.

解决方法是将 ios/Podfile 中的版本设置为至少 11,并在 Xcode 中更改 Deployment Target

开始使用

为了使用和测试 SDK,您需要一个 Usercentrics 帐户。请注册免费试用。

集成示例

以下是完整的 Flutter 示例代码:

import 'package:flutter/material.dart';
import 'package:usercentrics_sdk/usercentrics_sdk.dart';

void main() {
  WidgetsFlutterBinding.ensureInitialized();
  runApp(const MyApp());
}

class MyApp extends StatefulWidget {
  const MyApp({Key? key}) : super(key: key);

  [@override](/user/override)
  State<MyApp> createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  [@override](/user/override)
  void initState() {
    super.initState();
    _initializeUsercentrics();
  }

  // 初始化 Usercentrics
  void _initializeUsercentrics() {
    Usercentrics.initialize(
      settingsId: 'Yi9N3aXia', // 替换为您自己的 settingsId
      loggerLevel: UsercentricsLoggerLevel.debug,
    );
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return const MaterialApp(
      home: HomePage(),
    );
  }
}

class HomePage extends StatefulWidget {
  const HomePage({Key? key}) : super(key: key);

  [@override](/user/override)
  HomePageState createState() => HomePageState();
}

class HomePageState extends State<HomePage> {
  [@override](/user/override)
  void initState() {
    super.initState();
    _showCMPIfNeeded();
  }

  // 显示 CMP 如果需要
  void _showCMPIfNeeded() async {
    try {
      final status = await Usercentrics.status;

      if (status.shouldCollectConsent) {
        _showFirstLayer();
      } else {
        applyConsent(status.consents);
      }
    } catch (error) {
      // 处理非本地化错误
    }
  }

  // 显示第一层
  void _showFirstLayer({
    BannerSettings? settings,
  }) async {
    try {
      final response = await Usercentrics.showFirstLayer(
        settings: settings,
      );

      _handleUserResponse(response);
    } catch (error) {
      // 处理错误
    }
  }

  // 显示第二层
  void _showSecondLayer() async {
    try {
      final response = await Usercentrics.showSecondLayer(
        settings: BannerSettings(
          secondLayer: SecondLayerStyleSettings(
            showCloseButton: true,
            buttonLayout: ButtonLayout.row(
              buttons: [
                const ButtonSettings(type: ButtonType.save),
                const ButtonSettings(type: ButtonType.acceptAll),
              ],
            ),
          ),
        ),
      );

      _handleUserResponse(response);
    } catch (error) {
      // 处理错误
    }
  }

  // 处理用户响应
  void _handleUserResponse(UsercentricsConsentUserResponse? response) {
    print("Consents -> ${response?.consents}");
    print("User Interaction -> ${response?.userInteraction}");
    print("Controller Id -> ${response?.controllerId}");

    applyConsent(response?.consents);
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: const Text('Usercentrics Flutter Sample'),
      ),
      body: Padding(
        padding: const EdgeInsets.all(50.0),
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          crossAxisAlignment: CrossAxisAlignment.stretch,
          children: [
            ElevatedButton(
              onPressed: () => _showFirstLayer(),
              child: const Text("Show First Layer"),
            ),
            ElevatedButton(
              onPressed: () => _showSecondLayer(),
              child: const Text("Show Second Layer"),
            ),
          ],
        ),
      ),
    );
  }
}

// 应用同意
void applyConsent(List<UsercentricsServiceConsent>? consents) {
  // https://docs.usercentrics.com/cmp_in_app_sdk/latest/apply_consent/apply-consent/#apply-consent-to-each-service
}

更多关于Flutter用户隐私同意管理插件usercentrics_sdk的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html

1 回复

更多关于Flutter用户隐私同意管理插件usercentrics_sdk的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


当然,以下是如何在Flutter应用中使用usercentrics_sdk插件来管理用户隐私同意的一个代码示例。这个插件可以帮助你轻松地集成Usercentrics的隐私同意管理功能。

首先,确保你已经在pubspec.yaml文件中添加了usercentrics_sdk依赖:

dependencies:
  flutter:
    sdk: flutter
  usercentrics_sdk: ^最新版本号  # 请替换为实际的最新版本号

然后,运行flutter pub get来安装依赖。

接下来,在你的Flutter应用中,你可以按照以下步骤来初始化并使用usercentrics_sdk

  1. 初始化Usercentrics SDK

在你的应用的主入口文件(通常是main.dart)中,初始化Usercentrics SDK。你需要提供你的Usercentrics站点ID。

import 'package:flutter/material.dart';
import 'package:usercentrics_sdk/usercentrics_sdk.dart';

void main() {
  // 初始化Usercentrics SDK
  Usercentrics.initialize(
    siteId: '你的Usercentrics站点ID', // 替换为你的Usercentrics站点ID
    debug: true, // 仅在开发阶段设置为true,生产环境应设置为false
  );

  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: MyHomePage(),
    );
  }
}
  1. 检查用户同意状态

在应用的其他部分,你可以检查用户是否已经给予了隐私同意,并根据这个状态来决定是否显示某些功能或内容。

import 'package:flutter/material.dart';
import 'package:usercentrics_sdk/usercentrics_sdk.dart';

class MyHomePage extends StatefulWidget {
  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  bool _hasConsent = false;

  @override
  void initState() {
    super.initState();
    // 检查用户是否已经给予同意
    Usercentrics.checkConsent().then((hasConsent) {
      setState(() {
        _hasConsent = hasConsent;
      });
    });
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Usercentrics Demo'),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            Text(
              'User has given consent: $_hasConsent',
            ),
            SizedBox(height: 20),
            ElevatedButton(
              onPressed: () {
                // 打开Usercentrics同意弹窗
                Usercentrics.showBanner().then((result) {
                  // 用户操作后的回调,可以根据result做进一步处理
                  print('Usercentrics result: $result');
                });
              },
              child: Text('Show Usercentrics Banner'),
            ),
          ],
        ),
      ),
    );
  }
}

在这个示例中,当用户打开应用时,会检查他们是否已经给予了隐私同意。如果还没有给予同意,用户可以通过点击按钮来打开Usercentrics的同意弹窗。当用户做出选择后,你可以根据回调结果来处理相应的逻辑。

请确保你已经按照Usercentrics的文档配置了你的站点,并获取了正确的站点ID。此外,在实际的生产环境中,你应该将debug参数设置为false

这个示例提供了一个基本的使用方式,你可以根据实际需求进一步自定义和扩展功能。

回到顶部