本文将介绍GAE/J该应用程序不存在的详细情况,特别是关于app_id=u'application-id'的相关信息。我们将通过案例分析、数据研究等多种方式,帮助您更全面地了解这个主题,同时也将涉及一
本文将介绍GAE / J该应用程序不存在的详细情况,特别是关于app_id = u'application-id'的相关信息。我们将通过案例分析、数据研究等多种方式,帮助您更全面地了解这个主题,同时也将涉及一些关于android Application.mk文件的APP_MODULES:、Android ApplicationInfo 应用程序信息的详解、android – ApplicationStatus类E / SysUtils:ApplicationStat中的ApplicationContext为null、android – 使用MultiDexApplication会导致applicationContext变为null的知识。
本文目录一览:- GAE / J该应用程序不存在(app_id = u'application-id')(该应用不存在是什么意思)
- android Application.mk文件的APP_MODULES:
- Android ApplicationInfo 应用程序信息的详解
- android – ApplicationStatus类E / SysUtils:ApplicationStat中的ApplicationContext为null
- android – 使用MultiDexApplication会导致applicationContext变为null
GAE / J该应用程序不存在(app_id = u'application-id')(该应用不存在是什么意思)
我使用maven-gae-
plugin部署我的应用程序,在我决定将其部署到其他Google帐户下的另一个应用程序ID之前,它一直有效。我遇到了“此应用程序不存在”的问题。
我发现StackOverflow中已经有一些答案了,但是是针对python的,我正在使用GAE /
J。我想我知道根本原因,我们应该删除本地存储了我以前的用户名/密码的“缓存”,但是这些缓存是什么?他们在哪里?
或有其他方法可以避免这种情况,我尝试了很多方法,但都无济于事。
提前致谢。我在Window7,GAE1.6.3上
编辑:python版本答案在这里: 此应用程序不存在(app_id =xxx)
答案1
小编典典您可以使用该工具的新选项--no_cookies
(在此处记录)appcfg.sh
来防止加载cookie。或者,您可以删除至少在Linux中存储在中的cookie
/缓存文件~/.java/.userPrefs/com/google/appengine/tools/admin/prefs.xml
。
我没有使用maven-gae-plugin的经验,但是似乎您需要修改EngineGoalBase.java
文件以允许使用新参数。
android Application.mk文件的APP_MODULES:
jni中的Application.mk文件中的 APP_MODULES:属性表示application要编译的库有哪些,注意库名字的顺序,目前自己测试是按名字先后顺序编译,所以你需要根据你程序源文件的相互依赖关系决定库的编译顺序,顺序不对,找不到依赖的库会报错。自测,若有不对,欢迎拍砖!Android ApplicationInfo 应用程序信息的详解
Android ApplicationInfo 应用程序信息
1、简述
1 ApplicationInfo是android.content.pm包下的一个实体类,用于封装应用的信息,flags是其中的一个成员变量public int flags = 0;用于保存应用的标志信息。 2 ApplicationInfo 通过它可以得到一个应用基本信息。 这些信息是从AndroidManifest.xml的< application >标签获取的 3 ApplicationInfo对象里保存的信息都是<application>标签里的属性值 4 ApplicationInfo与ResolveInfo比较:前者能够得到Icon、Label、Meta-data、description。后者只能得到Icon、Label
2、获取ApplicationInfo
2.1 、获取手机上安装所有程序对应的 ApplicationInfo
/** * 获取手机上安装的所有的程序对应的 ApplicationInfo * 它是通过解析AndroidManifest.xml的< application>标签中得到的,所以它能得到所有的app * * 获取手机上的所有的安装的应用程序信息 * 参数为 标识 一般为 PackageManager.GET_UNINSTALLED_PACKAGES */ List<ApplicationInfo> list = packageManager.getInstalledApplications(PackageManager.GET_UNINSTALLED_PACKAGES);
2.2 、获取指定包名对应的 ApplicationInfo
/** * 获取指定应用程序 ApplicationInfo * 参数一对应应用程序的包名 * 参数二 应用程序对应的标识 通常为 0 */ ApplicationInfo applicationInfo = packageManager.getApplicationInfo("com.androidlongs.contactsapplication",0);
3、通过ApplicationInfo来获取应用程序的 基本信息
3.1 、获取应用程序对应的包名、应用名称
//获取应用图标 Drawable drawable = applicationInfo.loadIcon(packageManager); //获取应用程序的 包名 String appPackageName = applicationInfo.packageName; //获取应用名 //参数 packageManager 是应用管理者对象 String appName =applicationInfo.loadLabel(packageManager).toString();
3.2 、获取应用程序对应数据的目录以及占用的空间大小
//获取应用存放数据目录 String dir = applicationInfo.sourceDir; Log.d("app ","应用存放数据目录 " +dir); //获取应用数据大小 ong length = new File(dir).length(); //转换为 M float size = length*1f/1024/1024; Log.d("app ","应用数据大小 " +length+"\t"+size);
3.3 、判断是否安装在外置储存空间存
//判断是否安装在外存 int flags = applicationInfo.flags; if((flags&ApplicationInfo.FLAG_EXTERNAL_STORAGE)==ApplicationInfo.FLAG_EXTERNAL_STORAGE){ Log.d("app "," 安装在 外置存储空间 "); }else { Log.d("app "," 安装在 内置存储空间 "); }
3.4 、判断应用程序是否是系统应用
//判断是否是系统应用 if((flags&ApplicationInfo.FLAG_SYstem)==ApplicationInfo.FLAG_SYstem){ Log.d("app "," 是系统应用 "); }else{ Log.d("app "," 不是系统应用 "); }
3.5 、manageSpaceActivityName
/** * 从”android:manageSpaceActivity“属性得到 * 用于指定一个Activity来管理数据, * 它最终会出现在设置->应用程序管理中, * 默认为按钮为”清除数据”,指定此属性后,该按钮可点击跳转到该Activity,让用户选择性清除哪些数据。若不设置则为null. */ String activityName = applicationInfo.manageSpaceActivityName; Log.i("applicationInfo","activityName: " + activityName);
3.6 、获取应用程序运行的进程
/** * 从”android:process“属性得到,注明应用运行的进程名。或不设置则默认为应用包名。 */ String processName = applicationInfo.processName; Log.i("applicationInfo","processName: " + processName);
3.7 、其他配置信息简述
// 配置文件中的android:backupAgent属性值,用于备份 String backupAgentName = applicationInfo.backupAgentName; Log.i("applicationInfo","backupAgentName: " + backupAgentName); // 获取继承Application类的对象,维护全局的Application状态 //但一般都不用继承的方式,可以通过Context.getApplicationContext()方法得到 String className = applicationInfo.className; Log.i("applicationInfo","className: " + className); /** * 可选项,访问当前应用所有组件需要声明的权限,从”android:permission“属性得到。 */ String permisson = applicationInfo.permission; Log.i("applicationInfo","permisson: " + permisson); // 创建对象时,传入的是GET_SHARED_LIBRARY_FILES该属性才有值 String[] files = applicationInfo.sharedLibraryFiles; Log.i("applicationInfo","files: " + files); // 存放数据的路径 应用数据目录。 String dataPath = applicationInfo.dataDir; Log.i("applicationInfo","dataPath: " + dataPath); // 本地路径 JNI本地库存放路径。 String nativePath = applicationInfo.nativeLibraryDir; Log.i("applicationInfo","nativePath:" + nativePath); // 公共资源路径 String punlicSourcePath = applicationInfo.publicSourceDir; Log.i("applicationInfo","punlicSourcePath: " + punlicSourcePath); // 资源路径 应用APK的全路径 String sourcePath = applicationInfo.sourceDir; Log.i("applicationInfo","sourcePath: " + sourcePath); /** * 当前应用所有Activity的默认task密切性。 * 可以参考ActivityInfo的taskAffinity,从”android:taskAffinity“属性得到。 * 具体taskAffinity是怎么影响到Activity在task的启动,后面会在Activity启动模式中细讲 */ String taskAffinity = applicationInfo.taskAffinity; Log.i("applicationInfo","taskAffinity: " + taskAffinity); // 如果是false,代表application里的所有组件都禁用 boolean enable = applicationInfo.enabled; Log.i("applicationInfo","enable: " + enable); // 表述资源文件的标识 int descriRes = applicationInfo.descriptionRes; Log.i("applicationInfo","descriRes: " + descriRes); int flag = applicationInfo.flags; Log.i("applicationInfo","flag: " + flag); // 指定smallest screen width的值,超过这个值,就要开启屏幕兼容 int compatibleWidth = applicationInfo.compatibleWidthLimitDp;//android:compatibleWidthLimitDp属性 Log.i("applicationInfo","compatibleWidth: " + compatibleWidth); // 同上,只是这时候用户无法禁止屏幕兼容模式,说明是强制启动屏幕兼容 int largestWidth = applicationInfo.largestWidthLimitDp;//android:largestWidthLimitDp属性 Log.i("applicationInfo","largestWidth: " + largestWidth); // 所需屏幕空间的最短尺寸,int samllestWidth = applicationInfo.requiresSmallestWidthDp;//android:requiresSmallestWidthDp属性 Log.i("applicationInfo","samllestWidth: " + samllestWidth); // 应用所需的最小sdk版本 int sdkVersion = applicationInfo.targetSdkVersion; Log.i("applicationInfo","sdkVersion: " + sdkVersion); int theme = applicationInfo.theme; Log.i("applicationInfo","theme: " + theme);//android:theme= int uid = applicationInfo.uid; Log.i("applicationInfo","uid: " + uid); // 配置文件中的uiOptions属性的值 int uiOptions = applicationInfo.uiOptions; Log.i("applicationInfo","uiOptions: " + uiOptions);
如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
android – ApplicationStatus类E / SysUtils:ApplicationStat中的ApplicationContext为null
E / SysUtils:ApplicationStat中的ApplicationContext为null
有谁知道ApplicationStatus类?我没有在我的项目中
它发生在我在openGL中快速渲染纹理时
解决方法
我的问题是在打开新意图时直接传递额外的变量,如下所示.
>调用代码:
intent.putExtra("markerdata: ",assetVO);
>接收代码:
markerdata = (HashMap<String,Object>) getIntent().getSerializableExtra("markerdata");
2天前升级到Android Studio 1.3后,我总是变为空.
所以我的工作是将传递的信息捆绑在一起:
>调用代码:
Bundle b = new Bundle(); b.putSerializable("markerdata",assetVO); intent.putExtras(b);
>接收代码:
Bundle extras = getIntent().getExtras(); markerdata = (HashMap<String,Object>) extras.getSerializable("markerdata");
现在它的工作原理.希望它可以帮助别人.
android – 使用MultiDexApplication会导致applicationContext变为null
应用程序现在安装正确,但我的应用程序上下文为空.以前有没有经历过这样的事情?
如果您需要代码示例,请告诉我,但由于应用程序崩溃,因为它无法获取应用程序上下文,我无法想到任何可以解释该问题的代码.
获取我的应用程序上下文如下:
TrackerApplication.getContext(); public class TrackerApplication extends MultiDexApplication { private static Context context; public TrackerApplication() { super(); context = this; } @Override protected void attachBaseContext(Context base) { super.attachBaseContext(base); MultiDex.install(this); } @Override public void onCreate() { super.onCreate(); Fabric.with(this,new Crashlytics()); } public static Context getContext() { return context; } }
然后当我打电话:
TrackerApplication.getContext().getSharedPreferences("MySettings",Context.MODE_PRIVATE);
我得到一个NullPointer.我的应用程序上下文为空.
添加了一个测试来解释这个问题.在我的Launch活动中,我添加了以下代码:
if (TrackerApplication.getContext() == null) { Log.i("TEST","Context is null"); } else { Log.i("TEST","What is the issue?"); }
LogCat始终打印出Context为null.
解决方法
1-从app完全删除了multidex代码.
2-清理项目.
3-建造项目.
4-再次将所有multidex代码添加到项目中.
5-再次清理并重建项目.
6-它刚开始工作……
不知道为什么它第一次没有工作,但现在它工作正常.
今天关于GAE / J该应用程序不存在和app_id = u'application-id'的讲解已经结束,谢谢您的阅读,如果想了解更多关于android Application.mk文件的APP_MODULES:、Android ApplicationInfo 应用程序信息的详解、android – ApplicationStatus类E / SysUtils:ApplicationStat中的ApplicationContext为null、android – 使用MultiDexApplication会导致applicationContext变为null的相关知识,请在本站搜索。
本文标签: