0

アプリを介してウェブサイトから携帯電話にデータを取得しようとしています! メインスレッドでのネットワークの使用を避けるために、AsyncTaskを使用してjsoupを試しました。それはすべて良いのですが、私のアプリは起動しません。以下のエラーはnullpointerexceptionです。コードとlogcatスニペットです

protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    mt= new MyTask();
    mt.execute(URL);
    mytext =(TextView)findViewById(R.id.mytext);
}
class MyTask extends AsyncTask<String, Void, String>{   
    Document doc;
    String abouttext;
    @Override
    protected void onPreExecute(){
        super.onPreExecute();
        mytext.setText("please wait...");
    }
    protected String doInBackground(String...params){

    String url=params[0];
    Document doc;

    try{
    doc = Jsoup.connect(url).get();
    Element about = doc.select("div.box-content").first();
    String abouttext = about.text();
    }
    catch(Exception e){
        e.printStackTrace();
    }

    return abouttext;
    }
    protected void onPostExecute(String result){
        super.onPostExecute(result);
        mytext.setText(result);
    }

}

ここにログがあります

09-21 18:50:36.746: E/Trace(778): error opening trace file: No such file or directory (2)
09-21 18:50:37.445: D/AndroidRuntime(778): Shutting down VM
09-21 18:50:37.445: W/dalvikvm(778): threadid=1: thread exiting with uncaught exception   (group=0x40a71930)
09-21 18:50:37.506: E/AndroidRuntime(778): FATAL EXCEPTION: main
09-21 18:50:37.506: E/AndroidRuntime(778): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.web/com.example.web.MainActivity}: java.lang.NullPointerException
09-21 18:50:37.506: E/AndroidRuntime(778):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180)
09-21 18:50:37.506: E/AndroidRuntime(778):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)

誰かが間違っていることを教えてください! ありがとう!

私が推測する全体のログを投稿します

09-21 19:52:34.164: D/AndroidRuntime(796): Shutting down VM
09-21 19:52:34.194: W/dalvikvm(796): threadid=1: thread exiting with uncaught exception (group=0x40a71930)
09-21 19:52:34.244: E/AndroidRuntime(796): FATAL EXCEPTION: main
09-21 19:52:34.244: E/AndroidRuntime(796): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.web/com.example.web.MainActivity}: java.lang.NullPointerException
09-21 19:52:34.244: E/AndroidRuntime(796):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180)
09-21 19:52:34.244: E/AndroidRuntime(796):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
09-21 19:52:34.244: E/AndroidRuntime(796):  at android.app.ActivityThread.access$600(ActivityThread.java:141)
09-21 19:52:34.244: E/AndroidRuntime(796):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
09-21 19:52:34.244: E/AndroidRuntime(796):  at android.os.Handler.dispatchMessage(Handler.java:99)
09-21 19:52:34.244: E/AndroidRuntime(796):  at android.os.Looper.loop(Looper.java:137)
09-21 19:52:34.244: E/AndroidRuntime(796):  at android.app.ActivityThread.main(ActivityThread.java:5041)
09-21 19:52:34.244: E/AndroidRuntime(796):  at java.lang.reflect.Method.invokeNative(Native Method)
09-21 19:52:34.244: E/AndroidRuntime(796):  at java.lang.reflect.Method.invoke(Method.java:511)
09-21 19:52:34.244: E/AndroidRuntime(796):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
09-21 19:52:34.244: E/AndroidRuntime(796):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
09-21 19:52:34.244: E/AndroidRuntime(796):  at dalvik.system.NativeStart.main(Native Method)
09-21 19:52:34.244: E/AndroidRuntime(796): Caused by: java.lang.NullPointerException
09-21 19:52:34.244: E/AndroidRuntime(796):  at com.example.web.MainActivity$MyTask.onPreExecute(MainActivity.java:37)
09-21 19:52:34.244: E/AndroidRuntime(796):  at android.os.AsyncTask.executeOnExecutor(AsyncTask.java:586)
09-21 19:52:34.244: E/AndroidRuntime(796):  at android.os.AsyncTask.execute(AsyncTask.java:534)
09-21 19:52:34.244: E/AndroidRuntime(796):  at com.example.web.MainActivity.onCreate(MainActivity.java:27)
09-21 19:52:34.244: E/AndroidRuntime(796):  at android.app.Activity.performCreate(Activity.java:5104)
09-21 19:52:34.244: E/AndroidRuntime(796):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
09-21 19:52:34.244: E/AndroidRuntime(796):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)
09-21 19:52:34.244: E/AndroidRuntime(796):  ... 11 more
4

2 に答える 2

0

まず、スコープ内で Document doc を 2 回宣言しています。

テキストについての返信だと思います。問題を与えている

サーバーへのサーバー接続がない場合、またはサーバーがエラー応答を返す場合、about テキストには何も含まれず、null になるとします。

about.text() メソッドの前に abouttext の初期化を宣言してみて、about.text が null 値を abouttext に設定していないかどうかを確認してください。

于 2013-09-21T19:14:18.617 に答える