2014-11-24 208 views
2

當我在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來錯誤...

+0

你能發表一些代碼嗎? – 2014-11-24 10:20:43

+0

是的,當然;) – 2014-11-24 10:26:27

+0

嘗試發佈AssetManager代碼。 – 2014-11-24 10:27:53

回答

4

錯誤是真的不明確的,但我發現這個問題:

我用AngularJs在我科爾多瓦的應用程序,並試圖disp已這奠定下一行:

<img src="{{profil.selection ? profil.template.selectedPicture : profil.template.picture}}"/> 

但是:

「在src屬性採用了棱角分明的標記像{{哈希}}不起作用 權」

從AngularJS文檔:https://docs.angularjs.org/api/ng/directive/ngSrc

所以,我的瀏覽器,在我的測試和開發過程中,我沒有問題,但是當我用cordova構建它時,m y應用程序崩潰並退出上面的錯誤。

我認爲這是一個與@JoffreyMaheo聯繫的錯誤評論:https://issues.apache.org/jira/browse/CB-2391,因爲{{hash}}沒有被解釋,所以圖片url不被識別並且產生空指針異常。

要糾正:我們必須使用「NG-SRC」和一切與它的工作:

<img ng-src="{{profil.selection ? profil.template.selectedPicture : profil.template.picture}}"/> 

我覺得這個問題就出現在科爾多瓦在網址中包含特殊字符。

所以,請注意網址中的特殊字符!

+0

這也是我的問題! 從現在起我崇拜你GeoffreyLalloué – leonprou 2014-12-27 07:55:13

相關問題