Как устранить сбой системной библиотеки Android (libwebcore.so)

Мой веб-просмотр Android дает сбой, и дамп ошибок от adb logcat сообщает мне, что libwebcore.so — это библиотека, вызывающая ошибку сегментации. Как решить эту проблему?

Мои первоначальные исследования привели меня к таким местам, как эта тема: Как использовать addr2line в Android, что, по сути, говорит о том, что нужно получить неразрезанную версию библиотеки и использовать утилиту addr2line для точного определения строки, вызывающей ошибку сегментации.

В приведенной выше ветке говорится: «Используйте файл .so в obj/local/armeabi, поскольку это неразрезанная версия»… но я не смог найти libwebcore.so нигде в /usr/local/android- ndk-r6 или /usr/local/android-sdk-mac_86 на моем Mac, и я нашел только урезанную версию libwebcore.so в /system/lib на устройстве Android.

Есть ли способ получить неразрезанную версию libwebcore.so? Или я просто не правильно к этому отношусь?


Для справки, вот дамп ошибки, выложенный adb logcat:

I/DEBUG   (   65): *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
I/DEBUG   (   65): Build fingerprint: 'google/passion/passion:2.3.4/GRJ22/121341:user/release-keys'
I/DEBUG   (   65): pid: 611, tid: 618  >>> com.swishly.gap <<<
I/DEBUG   (   65): signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr 00000000
I/DEBUG   (   65):  r0 00000002  r1 002f9564  r2 00000003  r3 008e79c8
I/DEBUG   (   65):  r4 00000000  r5 002f9700  r6 00000000  r7 4470baf4
I/DEBUG   (   65):  r8 4470bb64  r9 44520ea8  10 002ae048  fp 00000000
I/DEBUG   (   65):  ip 00000000  sp 4470bad0  lr a851857b  pc a851838e  cpsr 00000030
I/DEBUG   (   65):  d0  0061006300000000  d1  0064006500680000
I/DEBUG   (   65):  d2  0077007400650000  d3  004c006b00720000
I/DEBUG   (   65):  d4  007400610063006f  d5  0053006e006f0069
I/DEBUG   (   65):  d6  006300720075006f  d7  0000000000000065
I/DEBUG   (   65):  d8  0000000000000000  d9  0000000000000000
I/DEBUG   (   65):  d10 0000000000000000  d11 0000000000000000
I/DEBUG   (   65):  d12 0000000000000000  d13 0000000000000000
I/DEBUG   (   65):  d14 0000000000000000  d15 0000000000000000
I/DEBUG   (   65):  d16 41d39d979893f080  d17 41d39d9b0a07ff06
I/DEBUG   (   65):  d18 41106a1000000000  d19 4024000000000000
I/DEBUG   (   65):  d20 0000000000000000  d21 0000000000000000
I/DEBUG   (   65):  d22 4024000000000000  d23 0000000000000000
I/DEBUG   (   65):  d24 0000000000000000  d25 3ff0000000000000
I/DEBUG   (   65):  d26 0000000000000000  d27 bff0000000000000
I/DEBUG   (   65):  d28 0000000000000000  d29 3ff0000000000000
I/DEBUG   (   65):  d30 0000000000000000  d31 3ff0000000000000
I/DEBUG   (   65):  scr 20000013
I/DEBUG   (   65): 
I/DEBUG   (   65):          #00  pc 0021838e  /system/lib/libwebcore.so
I/DEBUG   (   65):          #01  pc 00218576  /system/lib/libwebcore.so
I/DEBUG   (   65):          #02  pc 002186f8  /system/lib/libwebcore.so
I/DEBUG   (   65):          #03  pc 0021873a  /system/lib/libwebcore.so
I/DEBUG   (   65):          #04  pc 0021875c  /system/lib/libwebcore.so
I/DEBUG   (   65):          #05  pc 0021879a  /system/lib/libwebcore.so
I/DEBUG   (   65):          #06  pc 0021febe  /system/lib/libwebcore.so
I/DEBUG   (   65):          #07  pc 00220df0  /system/lib/libwebcore.so
I/DEBUG   (   65):          #08  pc 0022147c  /system/lib/libwebcore.so
I/DEBUG   (   65):          #09  pc 00017e34  /system/lib/libdvm.so
I/DEBUG   (   65): 
I/DEBUG   (   65): code around pc:
I/DEBUG   (   65): a851836c 602303c2 eb03e002 602003c2 46206063 
I/DEBUG   (   65): a851837c bf00bd70 b510680b b1134604 1c426818 
I/DEBUG   (   65): a851838c 6820601a f7ff6023 4620fd55 bf00bd10 
I/DEBUG   (   65): a851839c 4604b510 fd1ef7ff f6534620 4620fa73 
I/DEBUG   (   65): a85183ac bf00bd10 4604b570 460e6cc0 f6acb168 
I/DEBUG   (   65): 
I/DEBUG   (   65): code around lr:
I/DEBUG   (   65): a8518558 d10242a5 2600462c 6823e017 f1b3b113 
I/DEBUG   (   65): a8518568 d1f83fff e7f33408 1d216878 f7ff1980 
I/DEBUG   (   65): a8518578 3408ff03 d00642a5 2b006823 f1b3d0f9 
I/DEBUG   (   65): a8518588 d1013fff 462ce7f5 42ac3604 e8bdd1ec 
I/DEBUG   (   65): a8518598 bf0081f0 b087b5f0 0710f100 4604ae03 
I/DEBUG   (   65): 
I/DEBUG   (   65): stack:
I/DEBUG   (   65):     4470ba90  00953a1c  
I/DEBUG   (   65):     4470ba94  a83da669  /system/lib/libwebcore.so
I/DEBUG   (   65):     4470ba98  9de0413c  
I/DEBUG   (   65):     4470ba9c  00000001  
I/DEBUG   (   65):     4470baa0  00953a18  
I/DEBUG   (   65):     4470baa4  0000a000  
I/DEBUG   (   65):     4470baa8  4470bb64  
I/DEBUG   (   65):     4470baac  44520ea8  
I/DEBUG   (   65):     4470bab0  002ae048  
I/DEBUG   (   65):     4470bab4  afd1362d  /system/lib/libc.so
I/DEBUG   (   65):     4470bab8  4470baf4  
I/DEBUG   (   65):     4470babc  00953a1c

person Hugo    schedule 04.10.2011    source источник
comment
Вы пытались проверить, почему ваш WebView вызывает сбой libwebcore.so? Я не думаю, что в системных библиотеках может быть серьезная ошибка.   -  person Caner    schedule 04.10.2011
comment
вот ссылка на исходный код WebView, который фактически загружает нативную библиотеку webcore. Я предлагаю вам попытаться определить, какой нативный метод может привести к сбою?   -  person Thomas Philipakis    schedule 06.10.2011


Ответы (2)


Вы можете проверить весь проект xcode WebKit вместе со всем проектом с открытым исходным кодом Android по ссылке, предоставленной Kerubu (я сделал это несколько месяцев назад, это занимает несколько гигабайт и часов...) и, возможно, создать свою собственную неразрезанную библиотеку .so (я не делал), но я сомневаюсь, что это самый простой способ решить эту проблему.

Редактировать: оказалось, что Android зеркалируется на github, вот проект WebCore.

Есть большая вероятность, что ваше приложение гораздо проще устранять неполадки, чем проект WebKit!

Позволю себе высказать дикую догадку:

Существуют известные ошибки с внедрением JavaScript (также здесь) только для некоторых устройств, которые, похоже, также влияют на некоторые рамки HTML-приложений. (например, PhoneGap, видимо), вы используете метод addJavascriptInterface? Если это так, есть обходной путь, вызывающий WebChromeClient onJsPrompt и анализирующий строку для выполнения собственных вызовов из веб-просмотра.

Java в JavaScript:

webview.loadUrl("javascript:alert('toto');");

javascript в java:

в джаваскрипте:

prompt('this is the message', 'this is the default value');

и в джаве:

WebChromeClient chromeClient = new WebChromeClient(){
  @Override
  public boolean onJsPrompt(WebView view, String url, String message, String defaultValue, android.webkit.JsPromptResult result){
      Log.d("javascriptPrompt", "prompt : "+url+"-"+message);
      // should log "javascriptPrompt, "prompt: null - this is the message"
      // parse the message and do whatever you want here
      result.confirm();
      return true;
  }
}
webview.setChromeClient(chromeClient);
person Thomas Philipakis    schedule 06.10.2011
comment
Спасибо, Томас, я думаю, вы правы: я надеялся, что трассировка стека libwebcore даст некоторые подсказки, потому что обстоятельства сбоя довольно сложно отследить, но это выглядит как много боли для очень небольшого выигрыша. С другой стороны, мое приложение выполняет внедрение JavaScript, так что спасибо много за предоставление этих ссылок - person Hugo; 13.10.2011

Не уверен на 100 %, но можно ли найти исходный код libwebkit.so в Проекте Android с открытым исходным кодом?

person D-Dᴙum    schedule 04.10.2011