1. 程式人生 > >安卓使用騰訊Bugly實現應用升級功能

安卓使用騰訊Bugly實現應用升級功能

百度搜索bugly登陸平臺,建立應用,獲取應該用ID,在應用程式程式碼中使用該ID就可以實現該應用與bugly平臺應用對接

進入bugly平臺之後會看到三個模組:異常上報,運營統計,應用升級。也就是說bugly平臺包含著三大功能,今天要研究的就是應用升級模組,此模組包含 全量更新和熱更新,這篇文章就是針對全量更新來寫的

應用更新步驟:

1.首先伺服器要有最新的apk包

2.應用啟動檢查是否為最新包,是則不更新,不是則彈出提示框提示下載更新

3.下載更新完成啟動更新後的應用

Bugly平臺省去了我們伺服器維護apk包的過程,由bugly平臺來維護,不需要我們伺服器寫任何程式碼,我們在應用更新模組,點擊發布新應用把最新的apk包傳上去,並設定升級配置如圖:


1.策略名稱:最好寫應用的版本號,是在平臺區分應用更新版本的

2.升級方式:推薦升級(介面實現下次再說,立即更新兩個按鈕) 強制升級(只顯示立即更新按鈕)

3.高階配置:設定一些傳送升級資訊的條件以及次數間隔等

4.彈窗樣式,選什麼樣式就是啥樣子不過可以自定義樣式程式碼裡寫樣式就可以

5.更新時必須填寫的,版本名字如圖的位置

6.更新說明,必填

填完這些東西就可以建立升級策略了,建立好之後,bugly後臺算是完成了,接著就是app程式碼怎麼寫了

https://bugly.qq.com/v2/sdkDownload 下載NDK 動態庫 3.3.1把lib裡的包考入專案

自動匯入(推薦)

使用Android Studio建立project

【File】-> 【New】->【New Project】

使用Android Studio建立project

gradle配置(重要)

Alt text

配置示例(路徑app/build.gradle):

  android {
        defaultConfig {
          ndk {
            //設定支援的SO庫架構
            abiFilters 'armeabi' //, 'x86', 'armeabi-v7a', 'x86_64', 'arm64-v8a'
          }
        }
      }
      dependencies {
          //註釋掉原有bugly的倉庫
//compile 'com.tencent.bugly:crashreport:latest.release'//其中latest.release指代最新版本號,也可以指定明確的版本號,例如2.3.2 compile 'com.tencent.bugly:crashreport_upgrade:latest.release'//其中latest.release指代最新版本號,也可以指定明確的版本號,例如1.2.0 compile 'com.tencent.bugly:nativecrashreport:latest.release' //其中latest.release指代最新版本號,也可以指定明確的版本號,例如2.2.0 }

引數配置

在AndroidMainfest.xml中進行以下配置:

1. 許可權配置

<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.READ_LOGS" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

2. Activity配置

<activity
    android:name="com.tencent.bugly.beta.ui.BetaActivity"
    android:configChanges="keyboardHidden|orientation|screenSize|locale"
    android:theme="@android:style/Theme.Translucent" />

3. 配置FileProvider

注意:如果您想相容Android N或者以上的裝置,必須要在AndroidManifest.xml檔案中配置FileProvider來訪問共享路徑的檔案。


 <provider
    android:name="android.support.v4.content.FileProvider"
    android:authorities="${applicationId}.fileProvider"
    android:exported="false"
    android:grantUriPermissions="true">
    <meta-data
        android:name="android.support.FILE_PROVIDER_PATHS"
        android:resource="@xml/provider_paths"/>
</provider>

如果你使用的第三方庫也配置了同樣的FileProvider, 可以通過繼承FileProvider類來解決合併衝突的問題,示例如下:

<provider
    android:name=".utils.BuglyFileProvider"
    android:authorities="${applicationId}.fileProvider"
    android:exported="false"
    android:grantUriPermissions="true"
    tools:replace="name,authorities,exported,grantUriPermissions">
    <meta-data
        android:name="android.support.FILE_PROVIDER_PATHS"
        android:resource="@xml/provider_paths"
        tools:replace="name,resource"/>
</provider>

這裡要注意一下,FileProvider類是在support-v4包中的,檢查你的工程是否引入該類庫。

在res目錄新建xml資料夾,建立provider_paths.xml檔案如下:


<?xml version="1.0" encoding="utf-8"?>
<paths xmlns:android="http://schemas.android.com/apk/res/android">
    <!-- /storage/emulated/0/Download/${applicationId}/.beta/apk-->
    <external-path name="beta_external_path" path="Download/"/>
    <!--/storage/emulated/0/Android/data/${applicationId}/files/apk/-->
    <external-path name="beta_external_files_path" path="Android/data/"/>
</paths>

這裡配置的兩個外部儲存路徑是升級SDK下載的檔案可能存在的路徑,一定要按照上面格式配置,不然可能會出現錯誤。


以上配置好之後就可使用升級策略了,下圖為一些常用Beta配置


最後別忘了初始化Bugly


其他更多引數,可以在Bugly文件中檢視,以下列舉幾個

新增可顯示彈窗的Activity

Beta.canShowUpgradeActs.add(MainActivity.class);

例如,只允許在MainActivity上顯示更新彈窗,其他activity上不顯示彈窗; 如果不設定預設所有activity都可以顯示彈窗。

設定是否顯示訊息通知

Beta.enableNotification = true;

如果你不想在通知欄顯示下載進度,你可以將這個介面設定為false,預設值為true。

設定Wifi下自動下載

Beta.autoDownloadOnWifi = false;

如果你想在Wifi網路下自動下載,可以將這個介面設定為true,預設值為false。

設定是否顯示彈窗中的apk資訊

Beta.canShowApkInfo = true;

如果你使用我們預設彈窗是會顯示apk資訊的,如果你不想顯示可以將這個介面設定為false。

關閉熱更新能力

Beta.enableHotfix = true;

升級SDK預設是開啟熱更新能力的,如果你不需要使用熱更新,可以將這個介面設定為false。

初始化統一介面

 Bugly.init(this, APP_ID, false);
詳細請檢視文件:https://bugly.qq.com/docs/user-guide/advance-features-android-beta/?v=20170912151050