当我在android 4.3+中启动我的cordova应用程序时,我没有任何问题。科尔多瓦应用程序的NullPointerException
但是,当我在Android 4.1.2上启动我的应用程序时,我有一个nullpointerexception,并且在应用程序,应用程序退出的第一个操作之后。
最后通话是一个回调函数:
var callback = function(){
$location.path('/profils');
};
,当 “/异型材” 推出后,getProfils服务方法被称为:
service.factory('HttpService', ['$http', '$location',
function($http, $location){
return {
getProfils: function(){
console.log('-> Get Profils');
uiUtils.showLoader();
return $http.get(URL).
then(
function success(response) {
uiUtils.hideLoader();
return response.data.Result;
},
function error(reason) {
uiUtils.hideLoader();
return false;
}
);
},
...
你可以看到下面的堆栈跟踪:
I/Web Console(8801): -> Get Profils:14
D/FirewallPolicy(2128): getURLFilterEnabled(true)
D/FirewallPolicy(2128): isUrlBlocked - Policy disabled
D/STATUSBAR-NetworkController(2265): refreshSignalCluster: data=0 bt=false
I/ClipboardServiceEx(2128): Send intent for dismiss clipboard dialog inside hideCurrentInputLocked() !
E/dalvikvm(8801): Class lookup Landroid/webkit/WebResourceResponse; attempted with exception pending
W/dalvikvm(8801): Pending exception is:
I/dalvikvm(8801): java.lang.NullPointerException:
I/dalvikvm(8801): at android.content.res.AssetManager.openAsset(Native Method)
I/dalvikvm(8801): at android.content.res.AssetManager.open(AssetManager.java:315)
I/dalvikvm(8801): at android.webkit.BrowserFrame.inputStreamForAndroidResource(BrowserFrame.java:849)
I/dalvikvm(8801): at android.webkit.BrowserFrame.shouldInterceptRequest(BrowserFrame.java:939)
I/dalvikvm(8801): at android.webkit.JWebCoreJavaBridge.nativeServiceFuncPtrQueue(Native Method)
I/dalvikvm(8801): at android.webkit.JWebCoreJavaBridge.handleMessage(JWebCoreJavaBridge.java:113)
I/dalvikvm(8801): at android.os.Handler.dispatchMessage(Handler.java:99)
I/dalvikvm(8801): at android.os.Looper.loop(Looper.java:137)
I/dalvikvm(8801): at android.webkit.WebViewCore$WebCoreThread.run(WebViewCore.java:1067)
I/dalvikvm(8801): at java.lang.Thread.run(Thread.java:856)
I/dalvikvm(8801): DALVIK THREADS:
I/dalvikvm(8801): (mutexes: tll=0 tsl=0 tscl=0 ghl=0)
I/dalvikvm(8801):
I/dalvikvm(8801): "main" prio=5 tid=1 NATIVE
I/dalvikvm(8801): | group="main" sCount=0 dsCount=0 obj=0x40eb2508 self=0x40e01b08
I/dalvikvm(8801): | sysTid=8801 nice=0 sched=0/0 cgrp=apps handle=1075203888
I/dalvikvm(8801): | schedstat=(645744814 318546031 1496) utm=45 stm=19 core=1
I/dalvikvm(8801): #00 pc 0000da70 /system/lib/libc.so (epoll_wait+12)
I/dalvikvm(8801): #01 pc 00014899 /system/lib/libutils.so (android::Looper::pollInner(int)+96)
I/dalvikvm(8801): #02 pc 00014b01 /system/lib/libutils.so (android::Looper::pollOnce(int, int*, int*, void**)+104)
I/dalvikvm(8801): #03 pc 00063553 /system/lib/libandroid_runtime.so (android::NativeMessageQueue::pollOnce(_JNIEnv*, int)+22)
I/dalvikvm(8801): #04 pc 0001df30 /system/lib/libdvm.so (dvmPlatformInvoke+112)
I/dalvikvm(8801): #05 pc 0004d183 /system/lib/libdvm.so (dvmCallJNIMethod(unsigned int const*, JValue*, Method const*, Thread*)+394)
I/dalvikvm(8801): #06 pc 00027360 /system/lib/libdvm.so
I/dalvikvm(8801): #07 pc 0002bc68 /system/lib/libdvm.so (dvmInterpret(Thread*, Method const*, JValue*)+180)
I/dalvikvm(8801): #08 pc 0005fbb7 /system/lib/libdvm.so (dvmInvokeMethod(Object*, Method const*, ArrayObject*, ArrayObject*, ClassObject*, bool)+374)
I/dalvikvm(8801): #09 pc 00067165 /system/lib/libdvm.so
I/dalvikvm(8801): #10 pc 00027360 /system/lib/libdvm.so
I/dalvikvm(8801): #11 pc 0002bc68 /system/lib/libdvm.so (dvmInterpret(Thread*, Method const*, JValue*)+180)
I/dalvikvm(8801): #12 pc 0005f8f1 /system/lib/libdvm.so (dvmCallMethodV(Thread*, Method const*, Object*, bool, JValue*, std::__va_list)+272)
I/dalvikvm(8801): #13 pc 00049773 /system/lib/libdvm.so
I/dalvikvm(8801): #14 pc 0004c4a1 /system/lib/libandroid_runtime.so
I/dalvikvm(8801): #15 pc 0004d663 /system/lib/libandroid_runtime.so (android::AndroidRuntime::start(char const*, char const*)+390)
I/dalvikvm(8801): #16 pc 00000dcf /system/bin/app_process
I/dalvikvm(8801): #17 pc 00017123 /system/lib/libc.so (__libc_init+38)
I/dalvikvm(8801): #18 pc 00000b34 /system/bin/app_process
I/dalvikvm(8801): at android.os.MessageQueue.nativePollOnce(Native Method)
I/dalvikvm(8801): at android.os.MessageQueue.next(MessageQueue.java:125)
I/dalvikvm(8801): at android.os.Looper.loop(Looper.java:124)
I/dalvikvm(8801): at android.app.ActivityThread.main(ActivityThread.java:4921)
I/dalvikvm(8801): at java.lang.reflect.Method.invokeNative(Native Method)
I/dalvikvm(8801): at java.lang.reflect.Method.invoke(Method.java:511)
I/dalvikvm(8801): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1027)
I/dalvikvm(8801): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:794)
I/dalvikvm(8801): at dalvik.system.NativeStart.main(Native Method)
I/dalvikvm(8801):
有没有人有一个想法如何解决它?
我有更多的日志,如果需要,但我认为这足够了...但也许不是因为我找不到问题的根源。
UPDATE:
清理所有的代码后,我发现确切的错误来源:
<img src="{{profil.selection ? profil.template.selectedPicture : profil.template.picture}}"/>
目前,不知道从三元或URL来错误...
你能发表一些代码吗? – 2014-11-24 10:20:43
是的,当然;) – 2014-11-24 10:26:27
尝试发布AssetManager代码。 – 2014-11-24 10:27:53