3

Apache の HttpComponents を使用してサーバーに接続する Android アプリケーションを作成しました。

私が使用したバージョンは 4.3 (最新) で、実行時以外はすべて問題ありません。

例外が発生しました

E/AndroidRuntime( 1699): java.lang.ExceptionInInitializerError
E/AndroidRuntime( 1699):        at org.apache.http.impl.conn.PoolingHttpClientConnectionManager$InternalConnectionFactory.<in
it>(PoolingHttpClientConnectionManager.java:487)
E/AndroidRuntime( 1699):        at org.apache.http.impl.conn.PoolingHttpClientConnectionManager.<init>(PoolingHttpClientConne
ctionManager.java:147)
E/AndroidRuntime( 1699):        at org.apache.http.impl.conn.PoolingHttpClientConnectionManager.<init>(PoolingHttpClientConne
ctionManager.java:136)
E/AndroidRuntime( 1699):        at org.apache.http.impl.conn.PoolingHttpClientConnectionManager.<init>(PoolingHttpClientConne
ctionManager.java:112)
E/AndroidRuntime( 1699):        at net.xnano.weatherlife.util.ApacheHTTP.<init>(ApacheHTTP.java:97)
E/AndroidRuntime( 1699):        at net.xnano.weatherlife.view.WeatherLifeActivity$3.<init>(WeatherLifeActivity.java:105)
E/AndroidRuntime( 1699):        at net.xnano.weatherlife.view.WeatherLifeActivity.onOptionsItemSelected(WeatherLifeActivity.j
ava:105)
E/AndroidRuntime( 1699):        at android.app.Activity.onMenuItemSelected(Activity.java:2548)
E/AndroidRuntime( 1699):        at com.android.internal.policy.impl.PhoneWindow.onMenuItemSelected(PhoneWindow.java:980)
E/AndroidRuntime( 1699):        at com.android.internal.view.menu.MenuBuilder.dispatchMenuItemSelected(MenuBuilder.java:735)
E/AndroidRuntime( 1699):        at com.android.internal.view.menu.MenuItemImpl.invoke(MenuItemImpl.java:149)
E/AndroidRuntime( 1699):        at com.android.internal.view.menu.MenuBuilder.performItemAction(MenuBuilder.java:874)
E/AndroidRuntime( 1699):        at com.android.internal.view.menu.ActionMenuView.invokeItem(ActionMenuView.java:547)
E/AndroidRuntime( 1699):        at com.android.internal.view.menu.ActionMenuItemView.onClick(ActionMenuItemView.java:115)
E/AndroidRuntime( 1699):        at android.view.View.performClick(View.java:4204)
E/AndroidRuntime( 1699):        at android.view.View$PerformClick.run(View.java:17355)
E/AndroidRuntime( 1699):        at android.os.Handler.handleCallback(Handler.java:725)
E/AndroidRuntime( 1699):        at android.os.Handler.dispatchMessage(Handler.java:92)
E/AndroidRuntime( 1699):        at android.os.Looper.loop(Looper.java:137)
E/AndroidRuntime( 1699):        at android.app.ActivityThread.main(ActivityThread.java:5041)
E/AndroidRuntime( 1699):        at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime( 1699):        at java.lang.reflect.Method.invoke(Method.java:511)
E/AndroidRuntime( 1699):        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
E/AndroidRuntime( 1699):        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
E/AndroidRuntime( 1699):        at dalvik.system.NativeStart.main(Native Method)
E/AndroidRuntime( 1699): Caused by: java.lang.ExceptionInInitializerError
E/AndroidRuntime( 1699):        at org.apache.http.impl.conn.ManagedHttpClientConnectionFactory.<init>(ManagedHttpClientConne
ctionFactory.java:72)
E/AndroidRuntime( 1699):        at org.apache.http.impl.conn.ManagedHttpClientConnectionFactory.<init>(ManagedHttpClientConne
ctionFactory.java:84)
E/AndroidRuntime( 1699):        at org.apache.http.impl.conn.ManagedHttpClientConnectionFactory.<clinit>(ManagedHttpClientCon
nectionFactory.java:59)
E/AndroidRuntime( 1699):        ... 25 more
E/AndroidRuntime( 1699): Caused by: java.lang.NoSuchFieldError: org.apache.http.message.BasicLineFormatter.INSTANCE
E/AndroidRuntime( 1699):        at org.apache.http.impl.io.DefaultHttpRequestWriterFactory.<init>(DefaultHttpRequestWriterFac
tory.java:52)
E/AndroidRuntime( 1699):        at org.apache.http.impl.io.DefaultHttpRequestWriterFactory.<init>(DefaultHttpRequestWriterFac
tory.java:56)
E/AndroidRuntime( 1699):        at org.apache.http.impl.io.DefaultHttpRequestWriterFactory.<clinit>(DefaultHttpRequestWriterF
actory.java:46)
E/AndroidRuntime( 1699):        ... 28 more

libs フォルダーに追加したライブラリ (jar アーカイブ内) がエクスポートされました。アプリケーションは、独自のライブラリではなく、内部の org.apache.http パッケージを使用しているようです。

IDE は Intellij Idea です。

誰かが私を助けてくれる前にこの問題を解決しましたか?

4

2 に答える 2

1

この問題は SO で数回発生します。私が取った解決策は、 httpclientandroidlibと呼ばれるライブラリの再パッケージ化されたバージョンを使用することでした。これは、 How to Override Android Api Class with a class available in added jar? で、この質問の新しいバージョンの解決策として提示されました。

于 2013-12-18T19:08:17.060 に答える
0

次の方法で独自のライブラリを使用できます

com.yourlibrary.MyClass myClass= new com.yourlibrary.MyClass();
于 2013-09-20T13:06:20.180 に答える