我有一个应用程序在Play商店上线了将近一年。我正在使用以下代码来检查当前版本并显示用户弹出窗口以更新新版本是否可用。
private boolean checkVersionNumber() {
boolean isCurrentVersion = true;
DebugLog.d(TAG + "https://play.google.com/store/apps/details?id=" + getPackageName());
VersionChecker versionChecker = new VersionChecker();
try {
String latestVersion = versionChecker.execute().get();
PackageInfo pInfo = getPackageManager().getPackageInfo(getPackageName(), 0);
String currentVersion = pInfo.versionName;
if (!TextUtils.isEmpty(latestVersion) && !TextUtils.isEmpty(currentVersion)) {
DebugLog.d(TAG + "checkVersionNumber: VERSIONS NOT EMPTY");
if (latestVersion.equalsIgnoreCase(currentVersion)) {
DebugLog.d(TAG + "checkVersionNumber: IS THE CURRENT VERSION");
isCurrentVersion = true;
} else {
DebugLog.d(TAG + "checkVersionNumber: IS THE CURRENT VERSION");
isCurrentVersion = false;
}
} else {
DebugLog.d(TAG + "checkVersionNumber: VERSIONS WERE EMPTY");
}
} catch (InterruptedException e) {
e.printStackTrace();
} catch (ExecutionException e) {
e.printStackTrace();
} catch (PackageManager.NameNotFoundException e) {
e.printStackTrace();
}
return isCurrentVersion;
}
下面是版本检查器的代码
public class VersionChecker extends AsyncTask<String, String, String> {
String newVersion;
@Override
protected String doInBackground(String... params) {
try {
newVersion = Jsoup.connect("https://play.google.com/store/apps/details?id=" + getPackageName())
.timeout(30000)
.userAgent("Mozilla/5.0 (Windows; U; WindowsNT 5.1; en-US; rv1.8.1.6) Gecko/20070725 Firefox/2.0.0.6")
.referrer("http://www.google.com").get()
.select("div[itemprop=softwareVersion]").first()
.ownText();
} catch (IOException e) {
e.printStackTrace();
}
return newVersion;
}
}
到目前为止,它工作正常。但在过去的一个月里,所有用户都低于崩溃。
java.lang.RuntimeException: An error occurred while executing doInBackground()
at android.os.AsyncTask$3.done(AsyncTask.java:325)
at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:354)
at java.util.concurrent.FutureTask.setException(FutureTask.java:223)
at java.util.concurrent.FutureTask.run(FutureTask.java:242)
at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:243)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
at java.lang.Thread.run(Thread.java:761)
Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String org.jsoup.nodes.Element.ownText()' on a null object reference
at com.myapp.activity.SplashActivity$VersionChecker.doInBackground(SplashActivity.java:190)
at com.myapp.activity.SplashActivity$VersionChecker.doInBackground(SplashActivity.java:176)
at android.os.AsyncTask$2.call(AsyncTask.java:305)
at java.util.concurrent.FutureTask.run(FutureTask.java:237)
我不确定出了什么问题。有谁知道这个 api 是否正常工作..???
解析当前版本的Play商店是一个非常糟糕的主意。Play商店可以随时更改其HTML格式(如您所发现的(。它还对有正当理由留在旧版本(例如他们正在旅行并且拥有非常昂贵的互联网(的用户进行了一段时间的严重对待。
更好的办法是使用 Firebase 远程配置之类的东西来配置应用的最低可接受版本。 在发布应用更新后的一段时间(可能是一两周(将其更新到最新版本。那边:
- 您可以完全控制流程
- Play 商店 HTML 更改不会导致崩溃
- 您让用户有机会控制何时升级到方便的时间