簡要:本系列文章講會對expo進行全面的介紹,本人從2017年6月份接觸expo以來,對expo的研究斷斷續續,一路走來將近10個月,廢話不多說,接下來你看到內容,講全部來與官網 我猜去全部機翻+個人修改補充+demo測試的形式,對expo進行一次大補血!歡迎加入expo興趣學習交流群:597732 ...
簡要:本系列文章講會對expo進行全面的介紹,本人從2017年6月份接觸expo以來,對expo的研究斷斷續續,一路走來將近10個月,廢話不多說,接下來你看到內容,講全部來與官網
我猜去全部機翻+個人修改補充+demo測試的形式,對expo進行一次大補血!歡迎加入expo興趣學習交流群:597732981
【之前我寫過一些列關於expo和rn入門配置的東i西,大家可以點擊這裡查看:從零學習rn開發】
相關文章:
Expo大作戰(一)--什麼是expo,如何安裝expo clinet和xde,xde如何使用
Expo大作戰(二)--expo的生命周期,expo社區交流方式,expo學習必備資源,開發使用expo時關註的一些問題
Expo大作戰(三)--針對已經開發過react native項目開發人員有針對性的介紹了expo,expo的局限性,開發時項目選型註意點等
Expo大作戰(四)--快速用expo構建一個app,expo中的關鍵術語
Expo大作戰(五)--expo中app.json 文件的配置信息
Expo大作戰(六)--expo開發模式,expo中exp命令行工具,expo中如何查看日誌log,expo中的調試方式
Expo大作戰(七)--expo如何使用Genymotion模擬器
Expo大作戰(八)--expo中的publish以及expo中的link,對link這塊東西沒有詳細看,大家可以來和我交流
接下來就開始擼碼
使用哨兵(Sentry)
Sentry是一個崩潰報告和聚合平臺,可為您提供“實時洞察生產部署信息以重現和解決崩潰問題”。
它會通知您用戶在使用應用程式時遇到的例外情況,並組織您從他們的Web儀錶板進行分類。自動報告的異常包括源映射堆棧跟蹤和其他相關上下文(設備ID,平臺,Expo verison等);您還可以提供特定於您的應用程式的其他上下文,如當前的路由和用戶標識。
為什麼Sentry?
Sentry對待React Native是一流的公民,我們與Sentry合作確保expo也是如此。
這很容易設置和使用。
它的規模可以滿足甚至最大的項目的需求。
它適用於大多數平臺,因此您可以使用相同的服務來報告您的伺服器,CLI或桌面應用程式錯誤,就像您用於Expo應用程式一樣。
我們相信它為我們在expo的項目。
每個月最多可以有10,000個活動免費。
將Sentry添加到您的exoi項目中
註冊一個Sentry帳戶並創建一個項目
註冊一個Sentry帳戶
一旦你註冊,你將被提示創建一個項目。輸入您的項目名稱並繼續。
現在系統會提示您配置您的應用程式,單擊“獲取您的DSN”鏈接並複製您的“公共DSN”,您很快就會需要它。
轉到Sentry API部分並創建一個授權令牌。您可以使用預設配置,該令牌將永遠不會提供給您的應用的用戶。複製您的授權令牌並保存以備後用。
轉到您的項目儀錶板,轉到sentry.io並點擊屏幕頂部的“選擇項目”,然後選擇您的項目。這是您將在後面看到異常情況的地方。現在,點擊右上角的“項目設置”,然後複製項目“短名稱”。然後點擊左上角的圖標以顯示您帳戶中的組織。點擊設置齒輪圖標並複製組織短名稱。你將需要這個信息為你的app.json設置。安裝並配置Sentry
確保您使用支持非同步/等待的Node的新版本(Node7.6+)
在你的項目中,安裝expo整合:npm i sentry-expo --save
在您的應用的主文件中添加以下內容(預設為App.js)。import Sentry from 'sentry-expo'; // Remove this once Sentry is correctly setup. Sentry.enableInExpoDevelopment = true; Sentry.config('your Public DSN goes here').install();打開app.json並添加一個postPublish鉤子:
{ "expo": { // ... your existing configuration "hooks": { "postPublish": [ { "file": "sentry-expo/upload-sourcemaps", "config": { "organization": "your organization's short name here", "project": "your project short name here", "authToken": "your auth token here" } } ] } }用源地圖發佈您的應用程式(Publish your app with sourcemaps)
使用postPublish掛鉤後,現在您只需點擊發佈即可自動上傳源地圖。根據您在app.json中指定的版本和我們後端的發佈ID,我們會在您每次點擊發佈時自動為Sentry分配一個獨特發佈版本 - 這意味著如果您忘記更新版本但點擊發佈,您仍然會獲得獨特的Sentry版本。如果你不熟悉在expo上發佈,你可以在這裡閱讀更多。報告語義錯誤
為了確保可靠地報告錯誤,Sentry推遲將數據報告給它們的後端,直到下次您在致命錯誤後載入應用程式,而不是在捕獲異常時報告它為止。它將堆棧跟蹤和其他元數據保存到AsyncStorage,併在應用程式啟動時立即發送。
在dev中預設禁用
除非在調用
Sentry.config({...}).install()
之前設置了Sentry.enableInExpoDevelopment = true
,否則所有開發/本地錯誤都將被忽略,只有應用程式版本會向Sentry報告錯誤。你可以調用像entry.captureException(new Error('Oops!'))
這樣的方法,但是這些方法將是no-op。
瞭解更多關於哨兵
Sentry不僅僅是捕捉致命錯誤,更多地瞭解如何使用Sentry。
下一張繼續介紹,這一篇主要介紹了:expo結合哨兵(sentry)進行錯誤異常記錄, 歡迎大家關註我的微信公眾號,這篇文章是否被大家認可,我的衡量標準就是公眾號粉絲增長人數。歡迎大家轉載,但必須保留本人博客鏈接!