Как получить имя пакета из любого места?

Мне известно о доступности Context.getApplicationContext () и View.getContext () , через которые я могу фактически вызвать Context.getPackageName (), чтобы получить имя пакета приложения.

Они работают, если я вызываю метод, к которому доступен объект View или Activity , но если я хочу найти имя пакета из полностью независимого classа без View или Activity , есть ли способ сделать это (прямо или косвенно )?

Идея состоит в том, чтобы иметь статическую переменную в вашем основном действии, созданную как имя пакета. Затем просто укажите эту переменную.

Вам придется инициализировать его в onCreate() основной деятельности:

Глобальный class:

 public static String PACKAGE_NAME; 

Затем..

 @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); PACKAGE_NAME = getApplicationContext().getPackageName(); } 

Затем вы можете получить доступ к нему через Main.PACKAGE_NAME .

Если вы используете плагин gradle-android-plugin для создания своего приложения, вы можете использовать

 BuildConfig.APPLICATION_ID 

для получения имени пакета из любой области, в том числе. статический.

Если со словом «где угодно» вы имеете в виду без явного Context (например, из фонового streamа), вы должны определить class в своем проекте, например:

 public class MyApp extends Application { private static MyApp instance; public static MyApp getInstance() { return instance; } public static Context getContext(){ return instance; // or return instance.getApplicationContext(); } @Override public void onCreate() { instance = this; super.onCreate(); } } 

Затем в manifest вам нужно добавить этот class в поле « Name на вкладке « Application ». Или отредактируйте xml и поставьте

  

а затем из любого места, где вы можете позвонить

 String packagename= MyApp.getContext().getPackageName(); 

Надеюсь, поможет.

Если вы используете построение gradleации, используйте это: BuildConfig.APPLICATION_ID чтобы получить имя пакета приложения.

 private String getApplicationName(Context context, String data, int flag) { final PackageManager pckManager = context.getPackageManager(); ApplicationInfo applicationInformation; try { applicationInformation = pckManager.getApplicationInfo(data, flag); } catch (PackageManager.NameNotFoundException e) { applicationInformation = null; } final String applicationName = (String) (applicationInformation != null ? pckManager.getApplicationLabel(applicationInformation) : "(unknown)"); return applicationName; } 

Вы можете получить имя своего пакета так:

 $ /path/to/adb shell 'pm list packages -f myapp' package:/data/app/mycompany.myapp-2.apk=mycompany.myapp 

Вот варианты:

 $ adb Android Debug Bridge version 1.0.32 Revision 09a0d98bebce-android -a - directs adb to listen on all interfaces for a connection -d - directs command to the only connected USB device returns an error if more than one USB device is present. -e - directs command to the only running emulator. returns an error if more than one emulator is running. -s  - directs command to the device or emulator with the given serial number or qualifier. Overrides ANDROID_SERIAL environment variable. -p  - simple product name like 'sooner', or a relative/absolute path to a product out directory like 'out/target/product/sooner'. If -p is not specified, the ANDROID_PRODUCT_OUT environment variable is used, which must be an absolute path. -H - Name of adb server host (default: localhost) -P - Port of adb server (default: 5037) devices [-l] - list all connected devices ('-l' will also list device qualifiers) connect [:] - connect to a device via TCP/IP Port 5555 is used by default if no port number is specified. disconnect [[:]] - disconnect from a TCP/IP device. Port 5555 is used by default if no port number is specified. Using this command with no additional arguments will disconnect from all connected TCP/IP devices. device commands: adb push [-p]   - copy file/dir to device ('-p' to display the transfer progress) adb pull [-p] [-a]  [] - copy file/dir from device ('-p' to display the transfer progress) ('-a' means copy timestamp and mode) adb sync [  ] - copy host->device only if changed (-l means list but don't copy) adb shell - run remote shell interactively adb shell  - run remote shell command adb emu  - run emulator console command adb logcat [  ] - View device log adb forward --list - list all forward socket connections. the format is a list of lines with the following format:  " "  " "  "\n" adb forward   - forward socket connections forward specs are one of: tcp: localabstract: localreserved: localfilesystem: dev: jdwp: (remote only) adb forward --no-rebind   - same as 'adb forward  ' but fails if  is already forwarded adb forward --remove  - remove a specific forward socket connection adb forward --remove-all - remove all forward socket connections adb reverse --list - list all reverse socket connections from device adb reverse   - reverse socket connections reverse specs are one of: tcp: localabstract: localreserved: localfilesystem: adb reverse --norebind   - same as 'adb reverse  ' but fails if  is already reversed. adb reverse --remove  - remove a specific reversed socket connection adb reverse --remove-all - remove all reversed socket connections from device adb jdwp - list PIDs of processes hosting a JDWP transport adb install [-lrtsdg]  - push this package file to the device and install it (-l: forward lock application) (-r: replace existing application) (-t: allow test packages) (-s: install application on sdcard) (-d: allow version code downgrade) (-g: grant all runtime permissions) adb install-multiple [-lrtsdpg]  - push this package file to the device and install it (-l: forward lock application) (-r: replace existing application) (-t: allow test packages) (-s: install application on sdcard) (-d: allow version code downgrade) (-p: partial application install) (-g: grant all runtime permissions) adb uninstall [-k]  - remove this app package from the device ('-k' means keep the data and cache directories) adb bugreport - return all information from the device that should be included in a bug report. adb backup [-f ] [-apk|-noapk] [-obb|-noobb] [-shared|-noshared] [-all] [-system|-nosystem] [] - write an archive of the device's data to . If no -f option is supplied then the data is written to "backup.ab" in the current directory. (-apk|-noapk enable/disable backup of the .apks themselves in the archive; the default is noapk.) (-obb|-noobb enable/disable backup of any installed apk expansion (aka .obb) files associated with each application; the default is noobb.) (-shared|-noshared enable/disable backup of the device's shared storage / SD card contents; the default is noshared.) (-all means to back up all installed applications) (-system|-nosystem toggles whether -all automatically includes system applications; the default is to include system apps) ( is the list of applications to be backed up. If the -all or -shared flags are passed, then the package list is optional. Applications explicitly given on the command line will be included even if -nosystem would ordinarily cause them to be omitted.) adb restore  - restore device contents from the  backup archive adb disable-verity - disable dm-verity checking on USERDEBUG builds adb enable-verity - re-enable dm-verity checking on USERDEBUG builds adb keygen  - generate adb public/private key. The private key is stored in , and the public key is stored in .pub. Any existing files are overwritten. adb help - show this help message adb version - show version num scripting: adb wait-for-device - block until device is online adb start-server - ensure that there is a server running adb kill-server - kill the server if it is running adb get-state - prints: offline | bootloader | device adb get-serialno - prints:  adb get-devpath - prints:  adb remount - remounts the /system, /vendor (if present) and /oem (if present) partitions on the device read-write adb reboot [bootloader|recovery] - reboots the device, optionally into the bootloader or recovery program. adb reboot sideload - reboots the device into the sideload mode in recovery program (adb root required). adb reboot sideload-auto-reboot - reboots into the sideload mode, then reboots automatically after the sideload regardless of the result. adb sideload  - sideloads the given package adb root - restarts the adbd daemon with root permissions adb unroot - restarts the adbd daemon without root permissions adb usb - restarts the adbd daemon listening on USB adb tcpip  - restarts the adbd daemon listening on TCP on the specified port networking: adb ppp  [parameters] - Run PPP over USB. Note: you should not automatically start a PPP connection.  refers to the tty for PPP stream. Eg. dev:/dev/omap_csmi_tty1 [parameters] - Eg. defaultroute debug dump local notty usepeerdns adb sync notes: adb sync [  ]  can be interpreted in several ways: - If  is not specified, /system, /vendor (if present), /oem (if present) and /data partitions will be updated. - If it is "system", "vendor", "oem" or "data", only the corresponding partition is updated. environment variables: ADB_TRACE - Print debug information. A comma separated list of the following values 1 or all, adb, sockets, packets, rwx, usb, sync, sysdeps, transport, jdwp ANDROID_SERIAL - The serial number to connect to. -s takes priority over this if given. ANDROID_LOG_TAGS - When used with the logcat option, only these debug tags are printed. 

Создайте Java-модуль, который будет сначала запускаться при запуске вашего приложения. Этот модуль будет расширять class приложения Android и будет инициализировать любые глобальные переменные приложения, а также содержать общедоступные подпрограммы приложения –

 public class MyApplicationName extends Application { private final String PACKAGE_NAME = "com.mysite.myAppPackageName"; public String getPackageName() { return PACKAGE_NAME; } } 

Конечно, это может включать логику для получения имени пакета из системы Android; однако вышеизложенное является меньшим, быстрым и чистым кодом, чем получение его от android.

Обязательно поместите запись в свой файл AndroidManifest.xml, чтобы сообщить Android о запуске вашего прикладного модуля, прежде чем запускать какие-либо действия –

  

Затем, чтобы получить имя пакета из любого другого модуля, введите

 MyApp myApp = (MyApp) getApplicationContext(); String myPackage = myApp.getPackageName(); 

Использование модуля приложения также дает вам контекст для модhive, которые нуждаются, но не имеют контекста.

Вы можете использовать недокументированный метод android.app.ActivityThread.currentPackageName() :

 Class clazz = Class.forName("android.app.ActivityThread"); Method method = clazz.getDeclaredMethod("currentPackageName", null); String appPackageName = (String) method.invoke(clazz, null); 

Предостережение. Это должно быть сделано в основном streamе приложения.

Благодаря этому сообщению в блоге для этой идеи: http://blog.javia.org/static-the-android-application-package/ .

 PackageInfo pinfo = this.getPackageManager().getPackageInfo(getPackageName(), 0); String sVersionCode = pinfo.versionCode; // 1 String sVersionName = pinfo.versionName; // 1.0 String sPackName = getPackageName(); // cz.okhelp.my_app int nSdkVersion = Integer.parseInt(Build.VERSION.SDK); int nSdkVers = Build.VERSION.SDK_INT; 

Надеюсь, он сработает.

Для тех, кто использует Gradle, как упоминал @Billda, вы можете получить имя пакета через:

 BuildConfig.APPLICATION_ID 

Это дает вам имя пакета, объявленное в графе приложения:

 android { defaultConfig { applicationId "com.domain.www" } } 

Если вам интересно получить имя пакета, используемое вашими Java-classами (которое иногда отличается от applicationId ), вы можете использовать

 BuildConfig.class.getPackage().toString() 

Если вы запутались, какой из них использовать, читайте здесь :

Примечание. Идентификатор приложения был напрямую привязан к имени пакета вашего кода; поэтому некоторые API Android используют термин «имя пакета» в именах их методов и именах параметров, но на самом деле это ваш идентификатор приложения. Например, метод Context.getPackageName () возвращает ваш идентификатор приложения. Нет необходимости когда-либо передавать истинное имя вашего кода за пределами вашего кода приложения.

  • Java-пакеты com и org
  • Как передать ArrayList из одного действия в другое?
  • Найдите версию установленного пакета npm
  • Нет видимой привязки для глобальной переменной Примечание в R CMD check
  • Целевой пакет MSBuild не найден
  • Как проверить, установлен ли Facebook Android
  • Jar для Mac OSX App Bundle с приложением
  • Когда сетевой пакет TCP будет fragmentирован на уровне приложения?
  • Переопределить функцию, импортированную в пространстве имен
  • Как использовать Parcel в Android?
  • Как установить частный модуль NPM без моего собственного реестра?
  • Давайте будем гением компьютера.