Android アプリケーションの強制アップデートは非常に便利です。特に、起動したばかりのアプリケーションには、多かれ少なかれバグが必ずあります。特に、何か問題が発生すると、比較的大きな損失が発生するため、強制アップデートは特に重要です。
一般的に言えば、強制アップデートの戦略は次のとおりです:
アプリケーションの起動時にバックグラウンドをリクエストし、バックグラウンドは最新バージョンのアプリケーション情報 (アプリケーションのバージョン番号、名前、アップデート内容の説明、サーバーを含む) を送信します。ダウンロードパッケージのアドレス、強制アップデートフラグの有無など)。
それでは上記の考え方に基づいて実装コードを書いていきます。
1. AndroidManifest 構成のバージョン情報
各 Android APK のバージョン識別は AndroidManifest で定義されており、android:versionName="1.0.0" はバージョン コードです。 " はバージョン名であり、文字列でユーザーに表示されます。
AndroidManifest ファイル内のバージョン番号とバージョン名を読み取る必要がある場合は、packageManager を使用して簡単に取得できます。コードは次のとおりです:
<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.demo" android:versionCode="1" android:versionName="1.0.0"> <application> </application> </manifest>2. バージョンチェックを実行します 最新バージョンのapkファイルをサーバーに配置します(例: http://localhost/mydemo/demo.apk)。
同時に、サーバーは、この APK に対応するバージョン情報呼び出しインターフェイスまたはファイルを配置します。 http://localhost/mydemo/ver.json ver.json の内容は次のとおりです。
コードは次のとおりです:
[{"appname ":"jtapp12","apkname":"jtapp-12-updateapksamples.apk","verName":1.0.1,"verCode":2}]public static int getVerCode(Context context) { int verCode = -1; try { verCode = context.getPackageManager().getPackageInfo( "com.demo", 0).versionCode; } catch (NameNotFoundException e) { Log.e(TAG, e.getMessage()); } return verCode; } public static String getVerName(Context context) { String verName = ""; try { verName = context.getPackageManager().getPackageInfo( "com.demo", 0).versionName; } catch (NameNotFoundException e) { Log.e(TAG, e.getMessage()); } return verName; }
private boolean getServerVer () { try { String verjson = NetworkTool.getContent(Config.UPDATE_SERVER + Config.UPDATE_VERJSON); JSONArray array = new JSONArray(verjson); if (array.length() > 0) { JSONObject obj = array.getJSONObject(0); try { newVerCode = Integer.parseInt(obj.getString("verCode")); newVerName = obj.getString("verName"); } catch (Exception e) { newVerCode = -1; newVerName = ""; return false; } } } catch (Exception e) { Log.e(TAG, e.getMessage()); return false; } return true; }呼び出しメソッド:
if (getServerVerCode()) { int vercode = Config.getVerCode(this); // 用到前面第一节写的方法 if (newVerCode > vercode) { doNewVersionUpdate(); // 更新新版本 } else { notNewVersionShow(); // 提示当前为最新版本 } }アップデートのダウンロード:
private void notNewVersionShow() { int verCode = Config.getVerCode(this); String verName = Config.getVerName(this); StringBuffer sb = new StringBuffer(); sb.append("当前版本:"); sb.append(verName); sb.append(" Code:"); sb.append(verCode); sb.append(",\n已是最新版,无需更新!"); Dialog dialog = new AlertDialog.Builder(Update.this).setTitle("软件更新") .setMessage(sb.toString())// 设置内容 .setPositiveButton("确定",// 设置确定按钮 new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { finish(); } }).create();// 创建 // 显示对话框 dialog.show(); } private void doNewVersionUpdate() { int verCode = Config.getVerCode(this); String verName = Config.getVerName(this); StringBuffer sb = new StringBuffer(); sb.append("当前版本:"); sb.append(verName); sb.append(" Code:"); sb.append(verCode); sb.append(", 发现新版本:"); sb.append(newVerName); sb.append(" Code:"); sb.append(newVerCode); sb.append(", 是否更新?"); Dialog dialog = new AlertDialog.Builder(Update.this) .setTitle("软件更新") .setMessage(sb.toString()) // 设置内容 .setPositiveButton("更新",// 设置确定按钮 new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { pBar = new ProgressDialog(Update.this); pBar.setTitle("正在下载"); pBar.setMessage("请稍候..."); pBar.setProgressStyle(ProgressDialog.STYLE_SPINNER); downFile(Config.UPDATE_SERVER + Config.UPDATE_APKNAME); } }) .setNegativeButton("暂不更新", new DialogInterface.OnClickListener() { public void onClick(DialogInterface dialog, int whichButton) { // 点击"取消"按钮之后退出程序 finish(); } }).create();// 创建 // 显示对话框 dialog.show(); }ダウンロードが完了し、ハンドラーを通じてメイン UI スレッドにダウンロード ダイアログ ボックスをキャンセルするように通知されます。
void downFile(final String url) { pBar.show(); new Thread() { public void run() { HttpClient client = new DefaultHttpClient(); HttpGet get = new HttpGet(url); HttpResponse response; try { response = client.execute(get); HttpEntity entity = response.getEntity(); long length = entity.getContentLength(); InputStream is = entity.getContent(); FileOutputStream fileOutputStream = null; if (is != null) { File file = new File( Environment.getExternalStorageDirectory(), Config.UPDATE_SAVENAME); fileOutputStream = new FileOutputStream(file); byte[] buf = new byte[1024]; int ch = -1; int count = 0; while ((ch = is.read(buf)) != -1) { fileOutputStream.write(buf, 0, ch); count += ch; if (length > 0) { } } } fileOutputStream.flush(); if (fileOutputStream != null) { fileOutputStream.close(); } down(); } catch (ClientProtocolException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } }.start(); }アプリケーションをインストールします
void down() { handler.post(new Runnable() { public void run() { pBar.cancel(); update(); } }); }APK アプリケーションをマーケットに公開すると、マーケットには、アプリケーションを自動的に更新したり、更新するかどうかを通知したりできる同様のモジュールが組み込まれていることがわかります。応用。したがって、独自のアプリケーションを自動的に更新する必要がある場合は、自分でアプリケーションを構築した方が便利ではないでしょうか。この記事で説明されているコードのほとんどは UpdateActivity.Java に実装されています。更新プロセスをよりわかりやすくするために、最初のランチャーのアクティビティにスレッドを作成して、サーバー上に更新があるかどうかを確認できます。更新があるときに UpdateActivity を開始すると、ユーザー エクスペリエンスがよりスムーズになります。
以上がこの記事の全内容です。皆さんの学習に役立つことを願っています。また、皆さんも PHP 中国語 Web サイトをサポートしていただければ幸いです。
Android アプリの強制アップデートに関連するその他の記事については、PHP 中国語 Web サイトに注目してください。