在移動開發過程當中,應用升級是必不可少的一個環節,因此,r_upgrade應用升級插件就出現了,這裏先鼓掌歡迎👏👏,下面是使用介紹php
Android和IOS的升級應用插件==Flutter應用升級插件android
使用Service或者DownloadManager
Android
熱更新在pubspec.yaml
文件添加下面代碼git
dependencies:
r_upgrade: last version
複製代碼
Android
和IOS
通用)void upgradeFromUrl()async{
bool isSuccess =await RUpgrade.upgradeFromUrl(
'https://www.baidu.com',
);
print(isSuccess);
}
複製代碼
void upgradeFromAndroidStore(){
bool isSuccess = await RUpgrade.upgradeFromAndroidStore(AndroidStore.BAIDU);
print('${isSuccess?'跳轉成功':'跳轉失敗'}');
}
複製代碼
RUpgrade.stream.listen((DownloadInfo info){
///...
});
複製代碼
info 裏包含的信息以下:github
字段 | 含義 |
---|---|
(int) id | 當前下載任務的id |
(int) max_length ( total已棄用 ) |
所需下載的總大小 (bytes) |
(int) current_length ( progress已棄用 ) |
當前已下載的大小 (bytes) |
(double) percent | 當前下載進度(0-100) |
(double) planTime | 計劃下載完成所需時間/秒 (須要.toStringAsFixed(0)) |
(String) path ( address已棄用 ) |
當前下載的文件路徑 |
(double) speed | 當前下載的速度kb/s |
(DownloadStatus) status | 當前下載狀態 STATUS_PAUSED 下載已暫停 STATUS_PENDING 等待下載 STATUS_RUNNING 下載中 STATUS_SUCCESSFUL 下載成功 STATUS_FAILED 下載失敗 STATUS_CANCEL 下載取消 |
注意: 部分http下載連接可能返回 max_length = -1
,請自行判斷json
目前分爲兩部分 useDownloadManager
:bash
true
: 調用系統的DownloadManager
進行下載
false
: 調用Service
進行下載(默認使用)
// [isAutoRequestInstall] 下載完成後自動彈出安裝
// [apkName] 安裝包的名字(須要包含.apk)
// [notificationVisibility] 通知欄顯示方式
// [useDownloadManager] 是否使用DownloadManager,默認不使用(DownloadManager不支持http下載,下載手動暫停,斷點續傳等,不建議使用)
void upgrade() async {
int id = await RUpgrade.upgrade(
'https://raw.githubusercontent.com/rhymelph/r_upgrade/master/apk/app-release.apk',
apkName: 'app-release.apk',isAutoRequestInstall: true);
}
複製代碼
useDownloadManager
:服務器
false
: id由調用upgrade
或調用getLastUpgradedId
後返回true
: id由調用upgrade
後返回void cancel() async {
bool isSuccess=await RUpgrade.cancel(id);
}
複製代碼
useDownloadManager
:微信
false
: id由調用upgrade
或調用getLastUpgradedId
後返回true
: id由調用upgrade
後返回void install() async {
bool isSuccess=await RUpgrade.install(id);
}
複製代碼
Service
)useDownloadManager
:markdown
false
: id由調用upgrade
或調用getLastUpgradedId
後返回void pause() async {
bool isSuccess=await RUpgrade.pause(id);
}
複製代碼
Service
)useDownloadManager
:網絡
false
: id由調用upgrade
或調用getLastUpgradedId
後返回void pause() async {
bool isSuccess=await RUpgrade.upgradeWithId(id);
// 返回 false 即表示歷來不存在此ID
// 返回 true
// 調用此方法前狀態爲 [STATUS_PAUSED]、[STATUS_FAILED]、[STATUS_CANCEL],將繼續下載
// 調用此方法前狀態爲 [STATUS_RUNNING]、[STATUS_PENDING],不會發生任何變化
// 調用此方法前狀態爲 [STATUS_SUCCESSFUL],將會安裝應用
// 當文件被刪除時,從新下載
}
複製代碼
Service
)該方法只會尋找當前應用版本名和版本號下下載過的ID
void getLastUpgradeId() async {
int id = await RUpgrade.getLastUpgradedId();
}
複製代碼
Service
)useDownloadManager
:
false
: id由調用upgrade
或調用getLastUpgradedId
後返回void getDownloadStatus()async{
DownloadStatus status = await RUpgrade.getDownloadStatus(id);
}
複製代碼
id
進行熱更新,下載的文件須要將新版本生成的isolate_snapshot_data
、kernel_blob.bin
、vm_snapshot_data
打進zip文件中下載 步驟:
flutter clean
清理build文件flutter build bundle
生成須要的產物,下面標記星號爲必須文件|- AssetManifest.json
|- FontManifest.json
|- fonts
|- ...
|- isolate_snapshot_data *
|- kernel-blob.bin *
|- LICENSE
|- packages
|- ...
|- vm_snapshot_data *
複製代碼
- 將標記星號的文件打包成zip文件,上傳到服務器
- 調用`RUpgrade.upgrade(...)`方法進行下載
- 下載完成後,將上面獲取到的id進行熱更新,調用以下代碼
複製代碼
bool isSuccess = await RUpgrade.hotUpgrade(id);
if (isSuccess) {
_state.currentState
.showSnackBar(SnackBar(content: Text('熱更新成功,3s後退出應用,請從新進入')));
Future.delayed(Duration(seconds: 3)).then((_){
SystemNavigator.pop(animated: true);
});
}else{
_state.currentState
.showSnackBar(SnackBar(content: Text('熱更新失敗,請等待更新包下載完成')));
}
複製代碼
- 重啓應用便可
複製代碼
注意,在Android應用中,請確保
AndroidManifest.xml
中聲明如下權限,並在6.0系統上進行動態受權,否則會調用升級方法將拋出權限異常
<uses-permission android:name="android.permission.REQUEST_INSTALL_PACKAGES" />
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
複製代碼
注意:目前熱更新尚處於測試階段,只支持Flutter代碼的變動,不支持資源文件等,熱更新形成的一切的後果插件的做者概不負責,由使用者承擔。
若是你想自定義通知欄顯示的內容, 能夠這樣作, 修改或添加文件路徑爲project/android/app/main/res/r_upgrade_value.xml
,添加下面代碼
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="r_upgrade_download_speech">%.2fkb/s</string>
<string name="r_upgrade_download_planTime">預計%.0f秒後完成</string>
<string name="r_upgrade_download_finish">下載完成</string>
<string name="r_upgrade_download_paused">下載被暫停</string>
<string name="r_upgrade_download_failed">下載失敗</string>
</resources>
複製代碼
而後.當你使用upgrade
方法時,你應該設置參數notificationStyle
,默認爲顯示預計完成時間.
/// Notification show style about content text
enum NotificationStyle {
speechAndPlanTime, // 100kb/s 預計1秒後完成
planTimeAndSpeech, // 預計1秒後完成 100kb/s
speech,// 100kb/s
planTime, // 預計1秒後完成
none, //
}
複製代碼
void upgradeFromAppStore() async {
bool isSuccess =await RUpgrade.upgradeFromAppStore(
'您的AppId',//例如:微信的AppId:414478124
);
print(isSuccess);
}
複製代碼
void getVersionFromAppStore() async {
String versionName = await RUpgrade.getVersionFromAppStore(
'您的AppId',//例如:微信的AppId:414478124
);
print(versionName);
}
複製代碼
結尾:Dart客棧已經推出
Aqueduct框架系列教程
專輯,歡迎喜歡學習Dart語言開發的小夥伴關注👏👏