E/AndroidRuntime:致命异常:Android 的 AsyncTask #1 错误

Posted

技术标签:

【中文标题】E/AndroidRuntime:致命异常:Android 的 AsyncTask #1 错误【英文标题】:E/AndroidRuntime: FATAL EXCEPTION: AsyncTask #1 ERROR for Android 【发布时间】:2019-02-07 12:53:23 【问题描述】:

我的代码如下。它在 android Studio 中出现错误。任何人请帮助我。我的 php 代码没问题,但为什么会出现这个错误?

Register.java

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;

public class Register extends AppCompatActivity 
    EditText et_name, et_number;


    @Override
    protected void onCreate(Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_register);

        et_name = (EditText) findViewById(R.id.nametxt);
        et_number = (EditText) findViewById(R.id.numbertxt);

    

    public void userReg(View view)

        String names = et_name.getText().toString();
        String numbers = et_number.getText().toString();

        String method = "register";
        BackgroundTask backgroundTask = new BackgroundTask(this);
        backgroundTask.execute(method,names,numbers);
        finish();


    

我的 Background.java 代码是

import android.content.Context;
import android.net.Uri;
import android.os.AsyncTask;
import android.widget.Toast;

import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLEncoder;

import javax.net.ssl.HttpsURLConnection;

public class BackgroundTask extends AsyncTask<String,Void,String> 

    Context ctx;

    BackgroundTask(Context ctx)

        this.ctx = ctx;

    

    @Override
    protected void onPreExecute() 
        super.onPreExecute();
    

    @Override
    protected String doInBackground(String... params) 
        String reg_url = "http://192.168.1.2/logins/register.php";
        String method = params[0];
        if(method.equals("register"))

            String name = params[1];
            String number = params[2];
            try 
                URL url = new URL(reg_url);
                HttpsURLConnection httpsURLConnection = (HttpsURLConnection) url.openConnection();
                httpsURLConnection.setRequestMethod("POST");
                httpsURLConnection.setDoOutput(true);
                OutputStream os = httpsURLConnection.getOutputStream();
                BufferedWriter bufferedWriter = new BufferedWriter(new OutputStreamWriter(os,"UTF-8"));
                String data = URLEncoder.encode("names","UTF-8")+"="+URLEncoder.encode(name,"UTF-8")+"&"
                        +URLEncoder.encode("numbers","UTF-8")+"="+URLEncoder.encode(number,"UTF-8");
                bufferedWriter.write(data);
                bufferedWriter.flush();
                bufferedWriter.close();
                os.close();
                InputStream IS = httpsURLConnection.getInputStream();
                IS.close();
                return "Registration Success...";
             catch (MalformedURLException e) 
                e.printStackTrace();
             catch (IOException e) 
                e.printStackTrace();
            


        

        return null;
    

    @Override
    protected void onProgressUpdate(Void... values) 
        super.onProgressUpdate(values);
    

    @Override
    protected void onPostExecute(String result) 
        Toast.makeText(ctx,result,Toast.LENGTH_LONG).show();
    

而我的 Androidmainfest.xml 是

<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />

Android Studio 错误是:

E/AndroidRuntime:致命异常:AsyncTask #1 进程:com.example.smtanverhossain.myphpmysqlapplication,PID:5445 java.lang.RuntimeException:执行 doInBackground() 时发生错误 在 android.os.AsyncTask$3.done(AsyncTask.java:300) 在 java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355) 在 java.util.concurrent.FutureTask.setException(FutureTask.java:222) 在 java.util.concurrent.FutureTask.run(FutureTask.java:242) 在 android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231) 在 java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587) 在 java.lang.Thread.run(Thread.java:818) 引起:java.lang.ClassCastException: com.android.okhttp.internal.http.HttpURLConnectionImpl 无法强制转换 到 javax.net.ssl.HttpsURLConnection 在 com.example.smtanverhossain.myphpmysqlapplication.BackgroundTask.doInBackground(BackgroundTask.java:46) 在 com.example.smtanverhossain.myphpmysqlapplication.BackgroundTask.doInBackground(BackgroundTask.java:19) 在 android.os.AsyncTask$2.call(AsyncTask.java:288) 在 java.util.concurrent.FutureTask.run(FutureTask.java:237) 在 android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231) 在 java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112) 在 java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587) 在 java.lang.Thread.run(Thread.java:818)

【问题讨论】:

【参考方案1】:

错误在日志中解释:Caused by: java.lang.ClassCastException: com.android.okhttp.internal.http.HttpURLConnectionImpl cannot be cast to javax.net.ssl.HttpsURLConnection

这意味着您不能在此行转换为 HttpsURLConnection

HttpsURLConnection httpsURLConnection = (HttpsURLConnection) url.openConnection();

这是因为您的网址使用HTTP 而不是HTTPS。当您使用HTTP 调用url.openConnection() 时,它返回一个HttpURLConnection,同样适用于HTTPS。这在documentation 中有说明。

解决方案应该是将所有HttpsURLConnection 替换为HttpURLConnection 并删除转换为HttpsURLConnection

【讨论】:

【参考方案2】:

@Tohu 的解决方案可能会解决您的投射错误,这是我想展示给您的东西,您正在将活动的上下文传递给您正在通过调用 finish() 销毁的异步任务,这可能会给当您显示带有活动上下文的 toast 时,您会出错。 因此,请确保提供有效的上下文,例如:-.

getApplicationContext()

【讨论】:

检查你的android版本,你必须在AndroidManifest.xml的元素中包含以下声明。 developers.google.com/maps/documentation/android-sdk/…

以上是关于E/AndroidRuntime:致命异常:Android 的 AsyncTask #1 错误的主要内容,如果未能解决你的问题,请参考以下文章

E / AndroidRuntime:致命异常:主PID:4435

E / AndroidRuntime:致命异常:Android的AsyncTask#1 ERROR

致命异常:TokenRefresher

如何修复:E/AndroidRuntime:致命例外:主进程:com.android.youtubedownloader,PID:9291

执行应用程序时返回异常 - Android

我的应用程序不断崩溃(致命异常)