Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/r/83.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 致命异常:AsyncTask#1由于没有internet连接?_Java_Android - Fatal编程技术网

Java 致命异常:AsyncTask#1由于没有internet连接?

Java 致命异常:AsyncTask#1由于没有internet连接?,java,android,Java,Android,我目前手机上没有3g,我正试图通过WIFI实现这一切,有什么建议吗?我想这就是为什么我会犯这个错误。 这里是异步类 class CreateNewProduct extends AsyncTask<String, String, String> { /** * Before starting background thread Show Progress Dialog * */ @Override protected void on

我目前手机上没有3g,我正试图通过WIFI实现这一切,有什么建议吗?我想这就是为什么我会犯这个错误。 这里是异步类

    class CreateNewProduct extends AsyncTask<String, String, String> {
    /**
     * Before starting background thread Show Progress Dialog
     * */
    @Override
    protected void onPreExecute() {
        super.onPreExecute();
        pDialog = new ProgressDialog(NewProductActivity.this);
        pDialog.setMessage("Creating Product..");
        pDialog.setIndeterminate(false);
        pDialog.setCancelable(true);
        pDialog.show();
    }

    /**
     * Creating product
     * */
    protected String doInBackground(String... args) {
        String name = inputName.getText().toString();
        String price = inputPrice.getText().toString();
        String description = inputDesc.getText().toString();

        // Building Parameters
        List<NameValuePair> params = new ArrayList<NameValuePair>();
        params.add(new BasicNameValuePair("name", name));
        params.add(new BasicNameValuePair("price", price));
        params.add(new BasicNameValuePair("description", description));

        // getting JSON Object
        // Note that create product url accepts POST method
        JSONObject json = jsonParser.makeHttpRequest(url_create_product,
                "POST", params);

        // check log cat fro response
        Log.d("Create Response", json.toString());

        // check for success tag
        try {
            int success = json.getInt(TAG_SUCCESS);

            if (success == 1) {
                // successfully created product
                Intent i = new Intent(getApplicationContext(), AllProductsActivity.class);
                startActivity(i);

                // closing this screen
                finish();
            } else {
                // failed to create product
            }
        } catch (JSONException e) {
            e.printStackTrace();
        }

        return null;
    }

    /**
     * After completing background task Dismiss the progress dialog
     * **/
    protected void onPostExecute(String file_url) {
        // dismiss the dialog once done
        pDialog.dismiss();
    }
class CreateNewProduct扩展了异步任务{
/**
*在启动后台线程显示进度对话框之前
* */
@凌驾
受保护的void onPreExecute(){
super.onPreExecute();
pDialog=newprogressdialog(NewProductActivity.this);
pDialog.setMessage(“创建产品…”);
pDialog.setUndeterminate(假);
pDialog.setCancelable(真);
pDialog.show();
}
/**
*创造产品
* */
受保护的字符串doInBackground(字符串…args){
字符串名称=inputName.getText().toString();
字符串价格=inputPrice.getText().toString();
字符串描述=inputDesc.getText().toString();
//建筑参数
List params=new ArrayList();
参数添加(新的BasicNameValuePair(“名称”),名称);
参数添加(新的BasicNameValuePair(“价格”,价格));
参数添加(新的BasicNameValuePair(“说明”,说明));
//获取JSON对象
//请注意,创建产品url接受POST方法
JSONObject json=jsonParser.makeHttpRequest(url\u create\u product,
“POST”,params);
//检查cat fro响应日志
d(“创建响应”,json.toString());
//检查成功标签
试一试{
int success=json.getInt(TAG_success);
如果(成功==1){
//已成功创建产品
Intent i=新Intent(getApplicationContext(),AllProductsActivity.class);
星触觉(i);
//关闭此屏幕
完成();
}否则{
//未能创建产品
}
}捕获(JSONException e){
e、 printStackTrace();
}
返回null;
}
/**
*完成后台任务后,关闭“进度”对话框
* **/
受保护的void onPostExecute(字符串文件\u url){
//完成后关闭对话框
pDialog.disclose();
}
以及错误日志

          11-28 05:30:40.525: E/WindowManager(6132): Activity com.example.androidhive.NewProductActivity has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView@425a2140 that was originally added here
                  11-28 05:30:40.525: E/WindowManager(6132): android.view.WindowLeaked: Activity com.example.androidhive.NewProductActivity has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView@425a2140 that was originally added here
                  11-28 05:30:40.525: E/WindowManager(6132):    at android.view.ViewRootImpl.<init>(ViewRootImpl.java:409)
                  11-28 05:30:40.525: E/WindowManager(6132):    at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:322)
                  11-28 05:30:40.525: E/WindowManager(6132):    at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:234)
                  11-28 05:30:40.525: E/WindowManager(6132):    at android.view.WindowManagerImpl$CompatModeWrapper.addView(WindowManagerImpl.java:153)
                  11-28 05:30:40.525: E/WindowManager(6132):    at android.view.Window$LocalWindowManager.addView(Window.java:559)
                  11-28 05:30:40.525: E/WindowManager(6132):    at android.app.Dialog.show(Dialog.java:277)
                  11-28 05:30:40.525: E/WindowManager(6132):    at com.example.androidhive.NewProductActivity$CreateNewProduct.onPreExecute(NewProductActivity.java:76)
                  11-28 05:30:40.525: E/WindowManager(6132):    at android.os.AsyncTask.executeOnExecutor(AsyncTask.java:586)
                  11-28 05:30:40.525: E/WindowManager(6132):    at android.os.AsyncTask.execute(AsyncTask.java:534)
                  11-28 05:30:40.525: E/WindowManager(6132):    at com.example.androidhive.NewProductActivity$1.onClick(NewProductActivity.java:56)
                  11-28 05:30:40.525: E/WindowManager(6132):    at android.view.View.performClick(View.java:4192)
                  11-28 05:30:40.525: E/WindowManager(6132):    at android.view.View$PerformClick.run(View.java:17254)
                  11-28 05:30:40.525: E/WindowManager(6132):    at android.os.Handler.handleCallback(Handler.java:615)
                  11-28 05:30:40.525: E/WindowManager(6132):    at android.os.Handler.dispatchMessage(Handler.java:92)
                  11-28 05:30:40.525: E/WindowManager(6132):    at android.os.Looper.loop(Looper.java:137)
                  11-28 05:30:40.525: E/WindowManager(6132):    at android.app.ActivityThread.main(ActivityThread.java:4950)
                  11-28 05:30:40.525: E/WindowManager(6132):    at java.lang.reflect.Method.invokeNative(Native Method)
                  11-28 05:30:40.525: E/WindowManager(6132):    at java.lang.reflect.Method.invoke(Method.java:511)
                  11-28 05:30:40.525: E/WindowManager(6132):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1004)
                  11-28 05:30:40.525: E/WindowManager(6132):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:771)
                  11-28 05:30:40.525: E/WindowManager(6132):    at dalvik.system.NativeStart.main(Native Method)
11-28 05:30:40.525:E/WindowManager(6132):Activity com.example.androidhive.NewProductActivity已泄漏window com.android.internal.policy.impl.PhoneWindow$DecorView@425a2140原来是加在这里的
11-28 05:30:40.525:E/WindowManager(6132):android.view.WindowLeaked:Activity com.example.androidhive.NewProductActivity已泄漏window com.android.internal.policy.impl.PhoneWindow$DecorView@425a2140原来是加在这里的
11-28 05:30:40.525:E/WindowManager(6132):在android.view.ViewRootImpl。(ViewRootImpl.java:409)
11-28 05:30:40.525:E/WindowManager(6132):在android.view.WindowManagerImpl.addView(WindowManagerImpl.java:322)
11-28 05:30:40.525:E/WindowManager(6132):在android.view.WindowManagerImpl.addView(WindowManagerImpl.java:234)
11-28 05:30:40.525:E/WindowManager(6132):在android.view.WindowManagerImpl$CompatModeWrapper.addView(WindowManagerImpl.java:153)
11-28 05:30:40.525:E/WindowManager(6132):在android.view.Window$LocalWindowManager.addView(Window.java:559)
11-28 05:30:40.525:E/WindowManager(6132):在android.app.Dialog.show(Dialog.java:277)
11-28 05:30:40.525:E/WindowManager(6132):位于com.example.androidhive.NewProductActivity$CreateNewProduct.onPreExecute(NewProductActivity.java:76)
11-28 05:30:40.525:E/WindowManager(6132):位于android.os.AsyncTask.executeOnExecutor(AsyncTask.java:586)
11-28 05:30:40.525:E/WindowManager(6132):在android.os.AsyncTask.execute(AsyncTask.java:534)
11-28 05:30:40.525:E/WindowManager(6132):位于com.example.androidhive.NewProductActivity$1.onClick(NewProductActivity.java:56)
11-28 05:30:40.525:E/WindowManager(6132):在android.view.view.performClick(view.java:4192)上
11-28 05:30:40.525:E/WindowManager(6132):在android.view.view$PerformClick.run(view.java:17254)
11-28 05:30:40.525:E/WindowManager(6132):在android.os.Handler.handleCallback(Handler.java:615)
11-28 05:30:40.525:E/WindowManager(6132):在android.os.Handler.dispatchMessage(Handler.java:92)上
11-28 05:30:40.525:E/WindowManager(6132):在android.os.Looper.loop(Looper.java:137)
11-28 05:30:40.525:E/WindowManager(6132):在android.app.ActivityThread.main(ActivityThread.java:4950)
11-28 05:30:40.525:E/WindowManager(6132):位于java.lang.reflect.Method.Invokenactive(本机方法)
11-28 05:30:40.525:E/WindowManager(6132):位于java.lang.reflect.Method.invoke(Method.java:511)
11-28 05:30:40.525:E/WindowManager(6132):位于com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1004)
11-28 05:30:40.525:E/WindowManager(6132):位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:771)
11-28 05:30:40.525:E/WindowManager(6132):在dalvik.system.NativeStart.main(本机方法)
还有我的AndroidManifest.xml

      <?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.androidhive"
android:versionCode="1"
android:versionName="1.0" >

<uses-sdk android:minSdkVersion="8" />

<application

    android:configChanges="keyboardHidden|orientation"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name" >


    <activity
        android:name=".MainScreenActivity"
        android:label="@string/app_name" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>

    <!-- All Product Activity -->
    <activity
        android:name=".AllProductsActivity"
        android:label="All Products" >
    </activity>

    <!-- Add Product Activity -->
    <activity
        android:name=".NewProductActivity"
        android:label="Add New Product" >
    </activity>

    <!-- Edit Product Activity -->
    <activity
        android:name=".EditProductActivity"
        android:label="Edit Product" >
    </activity>

</application>


<!--  Internet Permissions -->
 <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />



同时添加此权限

我认为您不应该在
doInBackground
doInBackground
中启动新活动。您应该从网站获取信息,并将其传递到
onPostExecute
中,在那里您应该移动代码以打开新活动。

您试图在退出后显示一个对话框活动。 看到这个了吗

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