Android 之 Sentry 集成

本文介绍了在Android中集成Sentry进行错误收集的方法,包括在Manifest文件中配置、导入gradle插件、创建Sentry工具类等。详细说明了DSN的生成规则,通过图文展示了创建项目、查看Client Keys、合并DSN的步骤,并进行了测试,提醒本地测试时手机网段要与服务器一致。

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

Manifest文件中

    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />

导入gradle插件

//sentry 崩溃收集
implementation 'io.sentry:sentry-android:1.7.16'
//标准化日志
implementation 'org.slf4j:slf4j-nop:1.7.25'

Sentry工具类

/**
 * author: Tommy
 * time  : 2019/5/16
 * desc  : 
 */
public class SentryUtils {

    //初始化sentry
    /**
     * Use the Sentry DSN (client key) from the Project Settings page on Sentry
     * String sentryDsn = "https://publicKey:secretKey@host:port/1?options";
     * String sentryDsn = "http://8c4a32c102b04f929f21356d7188c7c5:40945f7672654e949f572c98bf942fb2@10.10.19.203:9000/2";
     */
    public static void init(Context context, String sentryDsn) {
        Sentry.init(sentryDsn, new AndroidSentryClientFactory(context));
    }

    //主动发送Throwable消息
    public static void sendSentryExcepiton(Throwable throwable) {
        Sentry.capture(throwable);
    }

    //主动发送Event消息
    public static void sendSentryExcepiton(Event throwable) {
        Sentry.capture(throwable);
    }

    //主动发送EventBuilder消息
    public static void sendSentryExcepiton(EventBuilder throwable) {
        Sentry.capture(throwable);
    }

    public static void sendSentryExcepiton(String logger, Throwable throwable) {
        SentryUtils.sendSentryExcepiton(new EventBuilder().withMessage("try catch msg").withLevel(Event.Level.WARNING).withLogger(logger).withSentryInterface(new ExceptionInterface(throwable)));
    }
}

集成

String sentryDsn = "http://8c4a32c102b04f929f21356d7188c7c5:40945f7672654e949f572c98bf942fb2@10.10.19.203:9000/2";      
Context ctx = this.getApplicationContext();
SentryUtils.init(ctx, sentryDsn);

附上我测试项目的下载地址:https://download.csdn.net/download/u010381752/11185354

其实,很简单,就这么点东西,But……

关于 Dsn 

Dsn 是什么鬼?它是提交端与服务器的一个认证的KEY

具体的生成规则如下:

http://publicKey:secretKey@host:port/1?options

即:http 或者 https + :// + publicKey : secretKey @ 服务器地址: 端口 / Project ID

这么说肯定还有很多老铁不清楚,下面进行详细滴图文说明:

http://host:9000 登录你的 sentry 服务端【没有的出门左转,找到我的 Linux 之 sentry 服务器搭建】

第一步:创建一个项目

第二步:查看你的 Client Keys(DSN)

好,到这步看到三个东西:Public Key、Secret Key、Project ID

第三步:合并成你的 DSN

http://Public Key:Secret Key@host:9000/Project ID

即:http://8c4a32c102b04f929f21356d7188c7c5:40945f7672654e949f572c98bf942fb2@10.10.19.203:9000/2

OK,大功告成~!

需要说明一下的是,如果部署到线上,基本都会用到https的,所以,如果不是本地测试用的话,http 请改成 https了,这个根据你的实际情况而定了。

第四步:测试一波

运行app,进入页面,点击让app跑到  throw new NullPointerException()

然后app崩溃,接着到后台看看,发现收到错误信息,如下图:

PS:最后提醒一下大家,如果你是做本地测试,请一定确保 你手机的网段跟Sentry服务器是一个网段,否则是访问不到的,切记切记【云服务系统老铁自行跳过】

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
发出的红包

打赏作者

s清风s

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值