Come ottenere il numero di build / versione della tua applicazione Android?


Devo capire come ottenere o creare un numero di build per la mia applicazione Android. Ho bisogno del numero di build da visualizzare nell'interfaccia utente.

Devo fare qualcosa con AndroidManifest.xml ?




Answers


Uso:

try {
    PackageInfo pInfo = this.getPackageManager().getPackageInfo(getPackageName(), 0);
    String version = pInfo.versionName;
} catch (PackageManager.NameNotFoundException e) {
    e.printStackTrace();
}

E puoi ottenere il codice di versione usando questo

int verCode = pInfo.versionCode;



Se stai usando il plugin Gradle / Android Studio, dalla versione 0.7.0 , il codice di versione e il nome della versione sono disponibili staticamente in BuildConfig . Assicurati di importare il pacchetto dell'app e non un altro BuildConfig :

import com.yourpackage.BuildConfig;
...
int versionCode = BuildConfig.VERSION_CODE;
String versionName = BuildConfig.VERSION_NAME;

Nessun oggetto di contesto necessario!

Assicurati anche di specificarli nel tuo file build.gradle invece di AndroidManifest.xml .

defaultConfig {
    versionCode 1
    versionName "1.0"
}



Versione leggermente più breve se si desidera solo il nome della versione.

String versionName = context.getPackageManager()
    .getPackageInfo(context.getPackageName(), 0).versionName;



Utilizzando Gradle e BuildConfig

Ottenere il VERSION_NAME da BuildConfig

BuildConfig.VERSION_NAME

Sì, è così facile ora.

Restituisce una stringa vuota per VERSION_NAME?

Se stai ricevendo una stringa vuota per BuildConfig.VERSION_NAME leggere.

Ho continuato a ottenere una stringa vuota per BuildConfig.VERSION_NAME perché non stavo impostando versionName nel mio file di build Grade (ho migrato da ANT a Gradle). Quindi, ecco le istruzioni per assicurarti di impostare VERSION_NAME tramite Gradle.

build.gradle

def versionMajor = 3
def versionMinor = 0
def versionPatch = 0
def versionBuild = 0 // bump for dogfood builds, public betas, etc.

android {

  defaultConfig {
    versionCode versionMajor * 10000 + versionMinor * 1000 + versionPatch * 100 + versionBuild

    versionName "${versionMajor}.${versionMinor}.${versionPatch}"
  }

}

Nota: questo è del magistrale Jake Wharton .

Rimozione di versionName e versionCode da AndroidManifest.xml

E dato che ora hai impostato versionName e versionCode nel file build.gradle , puoi rimuoverli dal tuo file AndroidManifest.xml , se sono presenti.




Ci sono due parti che ti servono: android: versionCode android: versionName

versionCode è un numero e ogni versione dell'app che invii al Market deve avere un numero più alto dell'ultimo.

VersionName è una stringa e può essere qualsiasi cosa tu voglia che sia. È qui che definisci la tua app come "1.0" o "2.5" o "2 Alpha EXTREME!" o qualsiasi altra cosa

Esempio:

Per accedervi in ​​codice, fai qualcosa come:

PackageManager manager = this.getPackageManager();
PackageInfo info = manager.getPackageInfo(this.getPackageName(), 0);
Toast.makeText(this,
     "PackageName = " + info.packageName + "\nVersionCode = "
       + info.versionCode + "\nVersionName = "
       + info.versionName + "\nPermissions = " + info.permissions, Toast.LENGTH_SHORT).show();



Ecco una soluzione pulita , basata sulla soluzione di scottyab (edita da Xavi). Mostra come ottenere il contesto per primo, se non è fornito dal tuo metodo. Inoltre usa più linee invece di chiamare più metodi per riga. Questo rende più facile quando devi eseguire il debug dell'applicazione.

Context context = getApplicationContext(); // or activity.getApplicationContext()
PackageManager packageManager = context.getPackageManager();
String packageName = context.getPackageName();

String myVersionName = "not available"; // initialize String

try {
    myVersionName = packageManager.getPackageInfo(packageName, 0).versionName;
} catch (PackageManager.NameNotFoundException e) {
    e.printStackTrace();
}

Ora che hai ricevuto il nome della versione in String myVersionName , puoi impostarlo su TextView o qualsiasi altra cosa tu voglia ..

// set version name to a TextView
TextView tvVersionName = (TextView) findViewById(R.id.tv_versionName);
tvVersionName.setText(myVersionName);



Se utilizzi PhoneGap, quindi crea un plug-in personalizzato PhoneGap:

Crea una nuova classe nel pacchetto della tua app:

package com.Demo; //replace with your package name

import org.json.JSONArray;

import android.content.pm.PackageInfo;
import android.content.pm.PackageManager;
import android.content.pm.PackageManager.NameNotFoundException;

import com.phonegap.api.Plugin;
import com.phonegap.api.PluginResult;
import com.phonegap.api.PluginResult.Status;

public class PackageManagerPlugin extends Plugin {

    public final String ACTION_GET_VERSION_NAME = "GetVersionName";

    @Override
    public PluginResult execute(String action, JSONArray args, String callbackId) {
        PluginResult result = new PluginResult(Status.INVALID_ACTION);
        PackageManager packageManager = this.ctx.getPackageManager();

        if(action.equals(ACTION_GET_VERSION_NAME)) {
            try {
                PackageInfo packageInfo = packageManager.getPackageInfo(
                                              this.ctx.getPackageName(), 0);
                result = new PluginResult(Status.OK, packageInfo.versionName);
            }
            catch (NameNotFoundException nnfe) {
                result = new PluginResult(Status.ERROR, nnfe.getMessage());
            }
        }

        return result;
    }
}

Nel plugins.xml, aggiungi la seguente riga:

<plugin name="PackageManagerPlugin" value="com.Demo.PackageManagerPlugin" />

Nel tuo evento deviceready , aggiungi il seguente codice:

var PackageManagerPlugin = function() {

};
PackageManagerPlugin.prototype.getVersionName = function(successCallback, failureCallback) {
    return PhoneGap.exec(successCallback, failureCallback, 'PackageManagerPlugin', 'GetVersionName', []);
};
PhoneGap.addConstructor(function() {
    PhoneGap.addPlugin('packageManager', new PackageManagerPlugin());
});

Quindi, puoi ottenere l'attributo versionName eseguendo:

window.plugins.packageManager.getVersionName(
    function(versionName) {
        //do something with versionName
    },
    function(errorMessage) {
        //do something with errorMessage
    }
);

Derivato da qui e qui .




Un modo molto semplice è:

private String appVersion = BuildConfig.VERSION_NAME;



Fallo sempre con try catch block:

String versionName = "Version not found";

try {
    versionName = context.getPackageManager().getPackageInfo(context.getPackageName(), 0).versionName;
    Log.i(TAG, "Version Name: " + versionName);
} catch (NameNotFoundException e) {
    // TODO Auto-generated catch block
    Log.e(TAG, "Exception Version Name: " + e.getLocalizedMessage());
}



Ecco il metodo per ottenere il codice della versione:

public String getAppVersion() {
    String versionCode = "1.0";
    try {
        versionCode = getPackageManager().getPackageInfo(getPackageName(), 0).versionName;
    } catch (PackageManager.NameNotFoundException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
    return versionCode;
}



Ho SOLVE questo usando la classe Preference.

package com.example.android;

import android.content.Context;
import android.preference.Preference;
import android.util.AttributeSet;

public class VersionPreference extends Preference {
    public VersionPreference(Context context, AttributeSet attrs) {
        super(context, attrs);
        String versionName;
        final PackageManager packageManager = context.getPackageManager();
        if (packageManager != null) {
            try {
                PackageInfo packageInfo = packageManager.getPackageInfo(context.getPackageName(), 0);
                versionName = packageInfo.versionName;
            } catch (PackageManager.NameNotFoundException e) {
                versionName = null;
            }
            setSummary(versionName);
        }
    }
}



Per gli utenti di xamarin, utilizzare questo codice per ottenere il nome e il codice della versione

1) Nome versione:

public string getVersionName(){
      return Application.Context.ApplicationContext.PackageManager.GetPackageInfo(Application.Context.ApplicationContext.PackageName, 0).VersionName;
}

2) Codice versione:

public string getVersionCode(){
      return Application.Context.ApplicationContext.PackageManager.GetPackageInfo(Application.Context.ApplicationContext.PackageName, 0).VersionCode;
}



Se vuoi usarlo su xml, aggiungi sotto la riga del tuo file gradle:

applicationVariants.all { variant ->
    variant.resValue "string", "versionName", variant.versionName
}

E poi usalo sul tuo xml in questo modo:

<TextView
        android:gravity="center_horizontal"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="@string/versionName" />



Qualcuno che non ha bisogno di informazioni BuildConfig per l'interfaccia utente dell'applicazione, tuttavia, desidera utilizzare queste informazioni per impostare una configurazione del lavoro dell'elemento della configurazione o altre, come me.

C'è un file generato automaticamente, BuildConfig.java, nella directory del progetto finché si costruisce il progetto con successo.

{} WORKSPACE / costruire / generata / source / buildConfig / {debug | rilascio} / {PACKAGE} /BuildConfig.java

/**
* Automatically generated file. DO NOT MODIFY
*/
package com.XXX.Project;

public final class BuildConfig {
    public static final boolean DEBUG = Boolean.parseBoolean("true");
    public static final String APPLICATION_ID = "com.XXX.Project";
    public static final String BUILD_TYPE = "debug";
    public static final String FLAVOR = "";
    public static final int VERSION_CODE = 1;
    public static final String VERSION_NAME = "1.0.0";
}

Dividi le informazioni di cui hai bisogno tramite script python o altri strumenti. Ecco un esempio:

import subprocess
#find your BuildConfig.java
_BuildConfig = subprocess.check_output('find {WORKSPACE} -name BuildConfig.java', shell=True).rstrip()
#get the version name
_Android_version = subprocess.check_output('grep -n "VERSION_NAME" '+_BuildConfig, shell=True).split('"')[1]
print('Android version :’+_Android_version)

Per favore, scusate la mia limitata conoscenza dell'inglese, ma spero che questo aiuti.




Questo codice è stato menzionato sopra in pezzi ma qui è di nuovo tutto incluso. È necessario un blocco try / catch perché potrebbe generare un "NameNotFoundException".

try {
   String appVersion = getPackageManager().getPackageInfo(getPackageName(), 0).versionName;
} catch (PackageManager.NameNotFoundException e) {e.printStackTrace();}

Spero che questo semplifica le cose per qualcuno in fondo alla strada. :)




 package com.sqisland.android.versionview;

import android.app.Activity;
import android.content.pm.PackageInfo;
import android.content.pm.PackageManager;
import android.os.Bundle;
import android.widget.TextView;

public class MainActivity extends Activity {
  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    TextView textViewversionName = (TextView) findViewById(R.id.text);

    try {
        PackageInfo packageInfo = getPackageManager().getPackageInfo(getPackageName(), 0);
        textViewversionName.setText(packageInfo.versionName);

    }
    catch (PackageManager.NameNotFoundException e) {

    }

  }
}



Primo:

import android.content.pm.PackageManager.NameNotFoundException;

e quindi usa questo:

PackageInfo pInfo = null;
try {
     pInfo = getPackageManager().getPackageInfo(getPackageName(), 0);
} catch (NameNotFoundException e) {
     e.printStackTrace();
            }
String versionName = pInfo.versionName;



private String GetAppVersion(){
        try {
            PackageInfo _info = mContext.getPackageManager().getPackageInfo(mContext.getPackageName(), 0);
            return _info.versionName;
        } catch (PackageManager.NameNotFoundException e) {
            e.printStackTrace();
            return "";
        }
    }

    private int GetVersionCode(){
        try {
            PackageInfo _info = mContext.getPackageManager().getPackageInfo(mContext.getPackageName(), 0);
            return _info.versionCode;
        } catch (PackageManager.NameNotFoundException e) {
            e.printStackTrace();
            return -1;
        }
    }



prova questo:

try 
{
    device_version =  getPackageManager().getPackageInfo("com.google.android.gms", 0).versionName;
}
catch (PackageManager.NameNotFoundException e)
{
    e.printStackTrace();
}



Esempio per l'utilizzo di frammenti interni.

        import android.content.pm.PackageManager;
        .......

        private String VersionName;
        private String VersionCode;
        .......


        Context context = getActivity().getApplicationContext();

        /*Getting Application Version Name and Code*/
        try
        {

             VersionName = context.getPackageManager().getPackageInfo(context.getPackageName(), 0).versionName;

             /*I find usefull to convert vervion code into String, so it's ready for TextViev/server side checks*/ 

             VersionCode = Integer.toString(context.getPackageManager().getPackageInfo(context.getPackageName(), 0).versionCode);
        } catch (PackageManager.NameNotFoundException e)
        {
             e.printStackTrace();
        }

// DO SOMETHING USEFULL WITH THAT



Ci sono alcuni modi per ottenere versionCode e versionName .

  1. Ottieni la versione da PackageManager . Questo è il modo migliore per la maggior parte dei casi.
try {
    String versionName = packageManager.getPackageInfo(packageName, 0).versionName;
    int versionCode = packageManager.getPackageInfo(packageName, 0).versionCode;
} catch (PackageManager.NameNotFoundException e) {
    e.printStackTrace();
}
  1. BuildConfig.java da BuildConfig.java generato. Ma notate che se accedete a questi valori nella libreria restituirà la versione della libreria, non quella dell'app, che utilizza questa libreria. Quindi usa solo in progetti non librerie!
String versionName = BuildConfig.VERSION_NAME;
int versionCode = BuildConfig.VERSION_CODE;

Ci sono alcuni dettagli, ad eccezione dell'uso della seconda via nel progetto della biblioteca. Nel nuovo plugin Android Gradle (3.0.0+) sono state rimosse alcune funzionalità . Quindi, per ora, vale a dire l'impostazione di versioni diverse per sapori diversi che non funzionano correttamente.

Modo errato:

applicationVariants.all { variant ->
    println('variantApp: ' + variant.getName())

    def versionCode = {SOME_GENERATED_VALUE_IE_TIMESTAMP}
    def versionName = {SOME_GENERATED_VALUE_IE_TIMESTAMP}

    variant.mergedFlavor.versionCode = versionCode
    variant.mergedFlavor.versionName = versionName
}

Il codice sopra imposterà correttamente i valori in BuildConfig , ma da PackageManager riceverai 0 e null se non hai impostato la versione nella configurazione default . Quindi la tua app avrà il codice di versione 0 sul dispositivo.

C'è una soluzione alternativa: imposta la versione per l'output del file apk manualmente:

applicationVariants.all { variant ->
    println('variantApp: ' + variant.getName())

    def versionCode = {SOME_GENERATED_VALUE_IE_TIMESTAMP}
    def versionName = {SOME_GENERATED_VALUE_IE_TIMESTAMP}

    variant.outputs.all { output ->
        output.versionCodeOverride = versionCode
        output.versionNameOverride = versionName
    }
}