Androidアプリケーション強制アップデートAPP

高洛峰
リリース: 2017-02-28 16:04:49
オリジナル
3555 人が閲覧しました

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 サイトに注目してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!