Android应用程序在使用jsoup和AsyncTask时崩溃!(实际上甚至没有启动)

Android应用程序在使用jsoup和AsyncTask时崩溃!(实际上甚至没有启动),android,android-asynctask,Android,Android Asynctask,我正在尝试通过应用程序从网站获取数据到手机! 因此,我使用AsyncTask尝试了jsoup,以避免在主线程上使用网络。 好吧,这一切都很好,但我的应用程序甚至无法启动。它说的错误是nullpointerexception 下面是代码和logcat代码段 protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.a

我正在尝试通过应用程序从网站获取数据到手机! 因此,我使用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 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

首先,您在范围内两次声明文档文档

我想你的归来就在下一步;这是一个问题

假设没有服务器连接到服务器或服务器返回错误响应,那么您的about文本将不包含任何内容,它将为null


尝试在about.text()方法之前声明initializing abouttext,并检查about.text是否未将null值设置为abouttext..

问题之一是您试图从后台线程更新UI组件

 @Override
    protected void onProgressUpdate(Void... values) {
        super.onProgressUpdate(values);
        //since async works on different thread it cannot update the ui so we need to run the updating task on UI thread
// use the below code wherever you are changing Ui, like in prexcute, postexecute

       runOnUiThread(new Runnable() {

            @Override
            public void run() {
                // Stuff that updates the UI

            }
        });
    }
从错误来看,问题可能是url或查询前检查url是否为空,对于查询,由于在select()中css查询无效而发生错误,请尝试更改查询


使用断点来知道哪个代码正在使你的应用程序崩溃

不,那不行!我确实像你说的那样删除了doc的第二个声明,然后将abouttext初始化为HI,然后在下一行中写下“abouttext=about.text();”。但是它显示了相同的错误nullpointerException。还有其他建议吗?再想一想,它显示的那行错误指针已经改变,并且指向mt.execute(URL);09-21 19:18:53.447:E/AndroidRuntime(790):在com.example.web.MainActivity.onCreate(MainActivity.java:27)上,这是设置“abouttext=about.text();”之前的mt.execute(url),您正在检查的是about.text()是否为空…如果(about.text().toString()!=null){abouttext=about.text();}否则{abouttext=“text not set”}不工作。我怀疑它是否能到达那个地方,因为它仍然说无法启动!而且,默认情况下,Jsoup遵循重定向。但是,重定向的方式可能会导致您的问题。如果网站为此使用javascript,连接将不会被重定向,因为jsoup不支持javascript。这可能就是原因…你能告诉我们URL实际上是什么吗??
 @Override
    protected void onProgressUpdate(Void... values) {
        super.onProgressUpdate(values);
        //since async works on different thread it cannot update the ui so we need to run the updating task on UI thread
// use the below code wherever you are changing Ui, like in prexcute, postexecute

       runOnUiThread(new Runnable() {

            @Override
            public void run() {
                // Stuff that updates the UI

            }
        });
    }