错误信息
java.lang.NoClassDefFoundError:org.ksoap2.serialization.soapobject
- ERROR/AndroidRuntime(600): java.lang.NoClassDefFoundError: org.ksoap2.serialization.SoapObject
- at webservice.weather.WeatherActivity.getWeather(WeatherActivity.java:104)
- at webservice.weather.WeatherActivity.showWeather(WeatherActivity.java:84)
- at webservice.weather.WeatherActivity.access$0(WeatherActivity.java:80)
- at webservice.weather.WeatherActivity$1.onClick(WeatherActivity.java:75)
- at android.view.View.performClick(View.java:2408)
- at android.view.View$PerformClick.run(View.java:8816)
- at android.os.Handler.handleCallback(Handler.java:587)
- at android.os.Handler.dispatchMessage(Handler.java:92)
- at android.os.Looper.loop(Looper.java:123)
- at android.app.ActivityThread.main(ActivityThread.java:4627)
- at java.lang.reflect.Method.invokeNative(Native Method)
- at java.lang.reflect.Method.invoke(Method.java:521)
- at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
- at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
- at dalvik.system.NativeStart.main(Native Method)
找了很多资料,最后才发现是jar包的导入有问题。。。。以前开发java程序时导入jar包都是用一下的方法:
工程点击右键->Build Path->Add Libraries->User Library->选择包含需要的jar包的Library(如果没有的话就点击User Libraries新建一个Library,然后再选中)
但是,在Android中这样导入jar包会导致程序在模拟器中运行时抛出java.lang.NoClassDefFoundError异常,在Android中导入jar包的步骤如下:
工程点击右键->Build Path->Add External Archives->选择要导入的jar包
另外还有一个问题就是:Android模拟器访问Tomcat上部署的webservice程序时,不能用localhost或者本机IP,Android默认访问本机地址为10.0.2.2。
上面这样的解决办法都不行:
新解决办法:
在项目中新建一个文件夹libs,然后将KSOAP2的jar包copy到这个文件夹下,右键jar包—>build path——>add to build path