Java 我的应用程序未将数据发布到android上的MySQL数据库

Java 我的应用程序未将数据发布到android上的MySQL数据库,java,android,mysql,json,eclipse,Java,Android,Mysql,Json,Eclipse,我的应用程序无法将数据发布到Android上的MySQL数据库 应用程序没有响应,因为我添加了这行代码 //StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build(); //StrictMode.setThreadPolicy(policy); 没有这行代码它就会崩溃 //StrictMode.ThreadPolicy policy = new

我的应用程序无法将数据发布到Android上的MySQL数据库

应用程序没有响应,因为我添加了这行代码

//StrictMode.ThreadPolicy policy = new            StrictMode.ThreadPolicy.Builder().permitAll().build();
//StrictMode.setThreadPolicy(policy);
没有这行代码它就会崩溃

//StrictMode.ThreadPolicy policy = new            StrictMode.ThreadPolicy.Builder().permitAll().build();
//StrictMode.setThreadPolicy(policy);
这是我的密码

MainActivity.java

package com.example.testingtesting;

import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.HttpClient;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.message.BasicNameValuePair;

import android.annotation.SuppressLint;
import android.os.Bundle;
import android.os.StrictMode;
import android.support.v7.app.ActionBarActivity;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

public class MainActivity extends ActionBarActivity {
    EditText et1,et2,et3;
    Button b;
    InputStream is = null;
    @SuppressLint("NewApi")
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();
        StrictMode.setThreadPolicy(policy);
        setContentView(R.layout.activity_main);

        et1 = (EditText)findViewById(R.id.editText1);
        et2 = (EditText)findViewById(R.id.editText2);
        et3 = (EditText)findViewById(R.id.editText3);
        b = (Button)findViewById(R.id.button1);
        b.setOnClickListener(new View.OnClickListener() {

            @Override
            public void onClick(View v) {
                // TODO Auto-generated method stub
                String name = "" +et1.getText().toString();
                String age = "" +et2.getText().toString();
                String email = "" +et3.getText().toString();

                List<NameValuePair> list = new ArrayList<NameValuePair>();

                list.add(new BasicNameValuePair("name", name));
                list.add(new BasicNameValuePair("age", age));
                list.add(new BasicNameValuePair("email", email));

                try{
                    HttpClient httpClient = new DefaultHttpClient();
                    HttpPost httpPost = new HttpPost("http://10.0.2.2/testing.php");
                    httpPost.setEntity(new UrlEncodedFormEntity(list));
                    HttpResponse response = httpClient.execute(httpPost);
                    HttpEntity entity = response.getEntity();

                    is = entity.getContent();
                    String msg = "Data Entered Succesfully";
                    Toast.makeText(getApplicationContext(), msg, Toast.LENGTH_SHORT).show();
                }catch(ClientProtocolException e){
                    Log.e("ClientProtocol", "Log_tag");
                }catch(IOException e){
                    Log.e("Log_tag", "IOException");
                    e.printStackTrace();
                }
            }
        });
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();
        if (id == R.id.action_settings) {
            return true;
        }
        return super.onOptionsItemSelected(item);
    }
}

尝试探索JSON,在php中使用JSON_编码,以及尝试使用AsyncTask,或者更好地移动到Google Android Volley库,以保持最新/最快的可靠网络调用。

使用AsyncTask进行网络调用。如果targetsdkversion大于10,则无法执行任何网络任务。对于android 3.x或之后的版本,您必须严格使用asynctask

而且你仍然希望运行这个应用程序,而不是将你的android:targetSdkVersion降低到10或9,比我想象的要低。但我建议你把任务切换到异步


更多访问:

您是否在broswer中执行了您的服务?它是否工作?应用程序只是冻结。logcatapp中没有价值的信息会冻结,因为您没有使用AsynTask。感谢您的回复,我希望您与我分享一个关于如何实现AsyncTask的教程。请参考此答案-->我是Android和Java新手,我不知道如何在phpWell中进行JSON调用。开始时会很复杂。但是学习安卓截击很容易。你唯一的问题是用于json的PHP Web API,学习它需要时间/代码练习。你能分享一个教程来帮助我启动它吗。感谢这篇关于volley/json的文章,我似乎找不到任何简单的php api到json教程,但是:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.testingtesting"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="21" />
    <uses-permission android:name="android.permission.INTERNET"/>
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name=".MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

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

</manifest>
<?php
$con = mysql_connect('localhost', 'root', '');
mysql_select_db("newdb", $con);

$name = $_POST['name'];
$age = $_POST['age'];
$email = $_POST['email'];

mysql_query("insert into mytable(name, age, email) values('{$name}','{$age}','{$email}')");
//mysql_close();
?>
StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();
StrictMode.setThreadPolicy(policy);

09-15 09:51:04.629: D/dalvikvm(870): Not late-enabling CheckJNI (already on)
09-15 09:51:05.628: E/Trace(870): error opening trace file: No such file or directory (2)
09-15 09:51:06.998: D/gralloc_goldfish(870): Emulator without GPU emulation detected.
09-15 09:51:07.098: D/dalvikvm(870): GC_CONCURRENT freed 137K, 4% free 4352K/4516K, paused 5ms+3ms, total 198ms
09-15 09:53:27.838: I/Choreographer(870): Skipped 39 frames!  The application may be doing too much work on its main thread.
09-15 09:53:37.089: I/Choreographer(870): Skipped 32 frames!  The application may be doing too much work on its main thread.
09-15 09:53:38.789: D/AndroidRuntime(870): Shutting down VM
09-15 09:53:38.789: W/dalvikvm(870): threadid=1: thread exiting with uncaught exception (group=0x2bd39930)
09-15 09:53:38.828: E/AndroidRuntime(870): FATAL EXCEPTION: main
09-15 09:53:38.828: E/AndroidRuntime(870): android.os.NetworkOnMainThreadException
09-15 09:53:38.828: E/AndroidRuntime(870):  at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1117)
09-15 09:53:38.828: E/AndroidRuntime(870):  at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:84)
09-15 09:53:38.828: E/AndroidRuntime(870):  at libcore.io.IoBridge.connectErrno(IoBridge.java:127)
09-15 09:53:38.828: E/AndroidRuntime(870):  at libcore.io.IoBridge.connect(IoBridge.java:112)
09-15 09:53:38.828: E/AndroidRuntime(870):  at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:192)
09-15 09:53:38.828: E/AndroidRuntime(870):  at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:459)
09-15 09:53:38.828: E/AndroidRuntime(870):  at java.net.Socket.connect(Socket.java:842)
09-15 09:53:38.828: E/AndroidRuntime(870):  at org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:119)
09-15 09:53:38.828: E/AndroidRuntime(870):  at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:144)
09-15 09:53:38.828: E/AndroidRuntime(870):  at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
09-15 09:53:38.828: E/AndroidRuntime(870):  at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
09-15 09:53:38.828: E/AndroidRuntime(870):  at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
09-15 09:53:38.828: E/AndroidRuntime(870):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
09-15 09:53:38.828: E/AndroidRuntime(870):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
09-15 09:53:38.828: E/AndroidRuntime(870):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
09-15 09:53:38.828: E/AndroidRuntime(870):  at com.example.testingtesting.MainActivity$1.onClick(MainActivity.java:65)
09-15 09:53:38.828: E/AndroidRuntime(870):  at android.view.View.performClick(View.java:4202)
09-15 09:53:38.828: E/AndroidRuntime(870):  at android.view.View$PerformClick.run(View.java:17340)
09-15 09:53:38.828: E/AndroidRuntime(870):  at android.os.Handler.handleCallback(Handler.java:725)
09-15 09:53:38.828: E/AndroidRuntime(870):  at android.os.Handler.dispatchMessage(Handler.java:92)
09-15 09:53:38.828: E/AndroidRuntime(870):  at android.os.Looper.loop(Looper.java:137)
09-15 09:53:38.828: E/AndroidRuntime(870):  at android.app.ActivityThread.main(ActivityThread.java:5039)
09-15 09:53:38.828: E/AndroidRuntime(870):  at java.lang.reflect.Method.invokeNative(Native Method)
09-15 09:53:38.828: E/AndroidRuntime(870):  at java.lang.reflect.Method.invoke(Method.java:511)
09-15 09:53:38.828: E/AndroidRuntime(870):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
09-15 09:53:38.828: E/AndroidRuntime(870):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
09-15 09:53:38.828: E/AndroidRuntime(870):  at dalvik.system.NativeStart.main(Native Method)