七夕情人節到了,各種App都要忙著上新,抓住互聯網產品的節日熱點,結合應用的類別進行活動營銷,比如購物類App會在節日進行大促;旅游類App會推出各種優惠活動;短視頻和拍照App會推出各種節日限定特效、專屬貼紙等,
尤其是游戲類App,具有較強的社交屬性,在節日熱點一般都會進行版本更新,上線新皮膚新場景等,涉及到的內容很多,有時候版本更新包的資源太大,導致用戶更新時等待時間長,影響運營推廣和用戶下載體驗,這時只需要接入HMS Core Network Kit,就可大幅提升資源下載速率,
HMS Core Network Kit是一款網路基礎服務套件,聚合遠場網路通信優秀實踐,輔以RESTful、檔案上傳/下載等場景化介面,為您提供簡單易用、低時延、高吞吐和高安全的端云傳輸通道,除了可以提升檔案上傳/下載的速度和成功率,還可以在URL訪問網路場景中提升網路訪問速度,在弱網環境中可減少無效網路等待時間,且支持網路平滑遷移,

從圖中可以看出,集成Network Kit后下載速度提升約40%,
HMS Core Network Kit首先在QUIC 協議上疊加自研的大檔案擁塞控制演算法,通過高效的并發資料流,有效提升弱網下的吞吐量;其次,智能分片針對不同機器環境設定不同分片閾值及分片數,盡可能提升下載速度;同時也支持多任務并發執行及管理,任務斷點續傳,提升下載成功率,適用于與新版本升級、補丁升級、新場景地圖等相關資源加載、活動圖片、視頻下載等,
開發步驟
在進行開發之前,您需要完成必要的開發準備作業,詳情可見Network開發指導檔案,
SDK集成示例代碼如下:
dependencies {
// 使用Network Kit的網路請求功能
implementation 'com.huawei.hms:network-embedded: 6.0.0.300'
// 使用Network Kit的檔案上傳/下載功能
implementation 'com.huawei.hms:filemanager: 6.0.0.300'
}
因為Network Kit使用了Java 8的新特性,如:Lambda運算式、靜態介面方法等,所以Network Kit均需要為Gradle添加Java 8的環境編譯約束,
在“compileOptions”中添加如下編譯配置,
android{
compileOptions{
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
}
示例代碼
檔案上傳
檔案上傳功能可以通過如下操作實作,詳細開發程序和代碼實作可以參見codelab(檔案上傳/下載集成)和示例代碼,
- 當適配版本為Android6.0(API Level 23)及以上時,需要動態申請讀寫手機存盤權限(每個應用只需成功申請一次),
if (Build.VERSION.SDK_INT >= 23) {
if (checkSelfPermission(Manifest.permission.WRITE_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED ||
checkSelfPermission(Manifest.permission.READ_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) {
requestPermissions(new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE}, 1000);
requestPermissions(new String[]{Manifest.permission.READ_EXTERNAL_STORAGE}, 1001);
}
}
- 初始化全域上傳管理類UploadManager,
UploadManager upManager = (UploadManager) new UploadManager
.Builder("uploadManager")
.build(context);
- 構造請求體物件,我們以上傳檔案file1和file2為例,
Map<String, String> httpHeader = new HashMap<>();
httpHeader.put("header1", "value1");
Map<String, String> httpParams = new HashMap<>();
httpParams.put("param1", "value1");
// 替換成您需要上傳的目的地址,
String normalUrl = "https://path/upload";
// 替換成您需要上傳的檔案的地址,
String filePath1 = context.getString(R.string.filepath1);
// 替換成您需要上傳的檔案的地址,
String filePath2 = context.getString(R.string.filepath2);
// 構造POST請求物件,
try{
BodyRequest request = UploadManager.newPostRequestBuilder()
.url(normalUrl)
.fileParams("file1", new FileEntity(Uri.fromFile(new File(filePath1))))
.fileParams("file2", new FileEntity(Uri.fromFile(new File(filePath2))))
.params(httpParams)
.headers(httpHeader)
.build();
}catch(Exception exception){
Log.e(TAG,"exception:" + exception.getMessage());
}
- 創建FileUploadCallback請求回呼類,
FileUploadCallback callback = new FileUploadCallback() {
@Override
public BodyRequest onStart(BodyRequest request) {
// 檔案上傳開始時回呼此方法,
Log.i(TAG, "onStart:" + request);
return request;
}
@Override
public void onProgress(BodyRequest request, Progress progress) {
// 檔案上傳進度變化時回呼到此方法,
Log.i(TAG, "onProgress:" + progress);
}
@Override
public void onSuccess(Response<BodyRequest, String, Closeable> response) {
// 檔案上傳成功時回呼此方法,
Log.i(TAG, "onSuccess:" + response.getContent());
}
@Override
public void onException(BodyRequest request, NetworkException exception, Response<BodyRequest, String, Closeable> response) {
// 檔案上傳程序中網路發生例外,或請求被取消時回呼此方法,
if (exception instanceof InterruptedException) {
String errorMsg = "onException for canceled";
Log.w(TAG, errorMsg);
} else {
String errorMsg = "onException for:" + request.getId() + " " + Log.getStackTraceString(exception);
Log.e(TAG, errorMsg);
}
}
};
- 發送請求上傳指定檔案,并獲取上傳是否啟動成功,
當Result的getCode方法獲取的回傳值與靜態變數Result.SUCCESS一致則檔案上傳任務啟動成功,
Result result = upManager.start(request, callback);
// 上傳任務啟動是否成功,可以通過Result的getCode()方法獲取的回傳值是否與靜態變數Result.SUCCESS一致來判斷,
if (result.getCode() != Result.SUCCESS) {
Log.e(TAG, result.getMessage());
}
- 檔案上傳狀態回呼,
檔案上傳狀態改變時,步驟4創建的FileUploadCallback物件的不同回呼方法將被呼叫,
? 檔案上傳開始時,onStart方法會被呼叫,
? 檔案上傳進度改變時,onProgress方法會被呼叫,并可通過決議回呼的Progress物件,獲取上傳進度,
? 檔案上傳任務發生例外時,onException方法會被呼叫,
- 驗證上傳結果,
檔案上傳成功后會回呼到步驟4創建的FileUploadCallback請求回呼物件的onSuccess方法,
檔案下載
檔案下載功能可以通過如下操作實作,詳細開發程序和代碼實作請參見codelab(檔案上傳/下載集成)和示例代碼,
- 當適配版本為Android6.0(API Level 23)及以上時,需要動態申請讀寫手機存盤權限(每個應用只需成功申請一次),
if (Build.VERSION.SDK_INT >= 23) {
if (checkSelfPermission(Manifest.permission.WRITE_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED ||
checkSelfPermission(Manifest.permission.READ_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) {
requestPermissions(new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE}, 1000);
requestPermissions(new String[]{Manifest.permission.READ_EXTERNAL_STORAGE}, 1001);
}
}
- 初始化全域下載管理類DownloadManager,
DownloadManager downloadManager = new DownloadManager.Builder("downloadManager")
.build(context);
- 構造請求體物件,
// 替換成您需要下載的資源地址,
String normalUrl = "https://gdown.baidu.com/data/wisegame/10a3a64384979a46/ee3710a3a64384979a46542316df73d4.apk";
// 替換成您想要保存的目的地址,
String downloadFilePath = context.getExternalCacheDir().getPath() + File.separator + "test.apk";
// 構造GET請求體物件,
GetRequest getRequest = DownloadManager.newGetRequestBuilder()
.filePath(downloadFilePath)
.url(normalUrl)
.build();
- 創建FileRequestCallback請求回呼物件,
FileRequestCallback callback = new FileRequestCallback() {
@Override
public GetRequest onStart(GetRequest request) {
// 檔案下載開始時回呼此方法,
Log.i(TAG, "activity new onStart:" + request);
return request;
}
@Override
public void onProgress(GetRequest request, Progress progress) {
// 檔案下載進度變化時回呼此方法,
Log.i(TAG, "onProgress:" + progress);
}
@Override
public void onSuccess(Response<GetRequest, File, Closeable> response) {
// 檔案下載成功時回呼到此方法,
String filePath = "";
if (response.getContent() != null) {
filePath = response.getContent().getAbsolutePath();
}
Log.i(TAG, "onSuccess:" + filePath);
}
@Override
public void onException(GetRequest request, NetworkException exception, Response<GetRequest, File, Closeable> response) {
// 檔案下載程序中網路發生例外,或請求被暫停、取消時回呼此方法,
if (exception instanceof InterruptedException) {
String errorMsg = "onException for paused or canceled";
Log.w(TAG, errorMsg);
} else {
String errorMsg = "onException for:" + request.getId() + " " + Log.getStackTraceString(exception);
Log.e(TAG, errorMsg);
}
}
};
- 使用DownloadManager啟動下載任務并檢驗下載任務是否啟動成功,
當Result的getCode方法獲取的回傳值與靜態變數Result.SUCCESS一致則檔案下載任務啟動成功,
Result result = downloadManager.start(getRequest, callback);
if (result.getCode() != Result.SUCCESS) {
// 當通過result獲取到的值為Result.SUCCESS時,則下載任務啟動成功,否則啟動失敗,
Log.e(TAG, “start download task failed:” + result.getMessage());
}
- 檔案下載狀態回呼,
檔案下載狀態改變時,步驟4創建的FileRequestCallback請求回呼物件的不同方法將被呼叫,
? 檔案開始下載時,onStart方法會被呼叫,
? 檔案下載進度改變時,onProgress方法會被呼叫,并可通過決議回呼的Progress物件,獲取下載進度,
? 檔案下載任務發生例外時,onException方法會被呼叫,
- 驗證下載結果,
檔案下載成功后會回呼到步驟4創建的FileRequestCallback請求回呼物件的onSuccess方法,并可根據您設定的下載路徑在手機記憶體中查看到您下載的檔案,
了解更多詳情>>
訪問華為開發者聯盟官網
獲取開發指導檔案
華為移動服務開源倉庫地址:GitHub、Gitee
關注我們,第一時間了解 HMS Core 最新技術資訊~
轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/500892.html
標籤:Android
上一篇:基于南航app直減自動出票
