Android集成sentry坑

本文介绍如何解决在Android P及以上版本中因默认禁止HTTP请求而产生的异常问题,并提供具体的配置步骤来允许ClearText HTTP流量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

sentry官网网址:Android | Sentry Documentation

集成sentry的时候可能遇到这个异常: java.io.IOException: Cleartext HTTP traffic to XXX not permitted

因为从Android 6.0开始引入了对Https的推荐支持,与以往不同,Android P的系统上面默认所有Http的请求都被阻止了。
解决的办法简单来说可以通过在AnroidManifest.xml中的application显示设置:

<application android:usesCleartextTraffic="true">

本人集成是使用手动集成

1、先在自己的app的清单文件中加入一下代码:    

<application>
    <meta-data android:name="io.sentry.auto-init" android:value="false" />
</application>

2、在自己继承的Application中加入初始化代码如下:

 SentryAndroid.init(this, options -> {
      options.setDsn("https://examplePublicKey@o0.ingest.sentry.io/0");
      // Add a callback that will be used before the event is sent to Sentry.
      // With this callback, you can modify the event or, when returning null, also discard the event.
      options.setBeforeSend((event, hint) -> {
        if (SentryLevel.DEBUG.equals(event.getLevel()))
          return null;
        else
          return event;
      });
    });

3、dsn地址的@前面字符串的拼接的格式是examplepublickey=publickey:secretKey

Sentry是一款用于错误跟踪和日志管理的开源工具,它可以帮助开发者更好地理解和解决应用中的问题。要在Android项目中集成Sentry NDK (Native Development Kit) 功能,你需要按照以下步骤操作: 1. **添加依赖**: - 首先,在你的`build.gradle`文件的`dependencies`部分添加Sentry Android SDK的NDK版本,例如: ```groovy implementation 'com.sentry:sentry-native:4.x.y' ``` 请确保替换`x.y`为实际的Sentry版本。 2. **配置环境**: - 如果你的项目有原生模块(如C++或JNI),确保已安装必要的编译工具链,比如Android NDK。 - 创建`sentry.properties`文件,并提供你的Sentry DSN(数据发送地址): ```properties sentry_dsn=<your- 在你的C/C++源码中,包含Sentry相关的头文件并初始化SDK: ```c++ #include "sentry.h" int main() { sentry_init("app_name"); // 其他代码... return 0; } ``` 确保替换`"app_name"`为你应用的实际名称。 4. **报告异常**: - 当遇到错误时,创建一个崩溃报告: ```c++ void reportError(const char* message) { sentry_capture_message(message); // 或者捕获更详细的错误信息 sentry_set_tag("key", "value"); sentry_crash(); } ``` 5. **编译链接**: - 将上述代码整合到你的构建系统中,确保Sentry库被打包进最终的APK或AAB中。 6. **测试**: - 完成以上步骤后,运行应用并尝试触发错误。你应该能在Sentry平台上看到对应的报错信息。 记得查看Sentry官方文档(https://docs.sentry.io/platforms/android/)以获取最新的集成指南和最佳实践。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值