我正在使用 Android 应用程序中的一个函数将数据插入到 mysql 数据库中,但每次单击按钮执行它时它都会崩溃。这些是我得到的错误:
10-08 16:16:05.649: E/AndroidRuntime(19038): 致命异常:main 10-08 16:16:05.649:E/AndroidRuntime(19038):android.os.NetworkOnMainThreadException 10-08 16:16:05.649: E/AndroidRuntime(19038): 在 android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1125) 10-08 16:16:05.649:E/AndroidRuntime(19038):在java.net.InetAddress.lookupHostByName(InetAddress.java:385) 10-08 16:16:05.649:E/AndroidRuntime(19038):在java.net.InetAddress.getAllByNameImpl(InetAddress.java:236) 10-08 16:16:05.649:E/AndroidRuntime(19038):在java.net.InetAddress.getAllByName(InetAddress.java:214) 10-08 16:16:05.649:E/AndroidRuntime(19038):在org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:137) 10-08 16:16:05.649:E/AndroidRuntime(19038):在org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164) 10-08 16:16:05.649:E/AndroidRuntime(19038):在org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119) 10-08 16:16:05.649:E/AndroidRuntime(19038):在org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360) 10-08 16:16:05.649:E/AndroidRuntime(19038):在org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:670) 10-08 16:16:05.649:E/AndroidRuntime(19038):在org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:509) 10-08 16:16:05.649:E/AndroidRuntime(19038):在org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487) 10-08 16:16:05.649:E/AndroidRuntime(19038):在com.example.gloc.MainActivity.insert(MainActivity.java:360) 10-08 16:16:05.649:E/AndroidRuntime(19038):在com.example.gloc.MainActivity $ 3.onClick(MainActivity.java:217) 10-08 16:16:05.649: E/AndroidRuntime(19038): 在 android.view.View.performClick(View.java:4354) 10-08 16:16:05.649: E/AndroidRuntime(19038): 在 android.view.View$PerformClick.run(View.java:17961) 10-08 16:16:05.649:E/AndroidRuntime(19038):在android.os.Handler.handleCallback(Handler.java:725) 10-08 16:16:05.649: E/AndroidRuntime(19038): 在 android.os.Handler.dispatchMessage(Handler.java:92) 10-08 16:16:05.649:E/AndroidRuntime(19038):在android.os.Looper.loop(Looper.java:137) 10-08 16:16:05.649:E/AndroidRuntime(19038):在android.app.ActivityThread.main(ActivityThread.java:5328) 10-08 16:16:05.649:E/AndroidRuntime(19038):在java.lang.reflect.Method.invokeNative( native 方法) 10-08 16:16:05.649:E/AndroidRuntime(19038):在java.lang.reflect.Method.invoke(Method.java:511) 10-08 16:16:05.649: E/AndroidRuntime(19038): 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102) 10-08 16:16:05.649:E/AndroidRuntime(19038):在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869) 10-08 16:16:05.649:E/AndroidRuntime(19038):在dalvik.system.NativeStart.main( native 方法)
这是我的代码
public void insert(){
String input_data= "http://www.wolfdoginfo.net/app/dataapp.php"; //URL website anda dengan file insert.php yang telah dibuat
HttpClient httpClient = new DefaultHttpClient();
HttpPost httpPost = new HttpPost(input_data);
ArrayList<NameValuePair> param = new ArrayList<NameValuePair>();
final EditText reguser = (EditText) findViewById(R.id.usernamecomplete);
final EditText regpass = (EditText) findViewById(R.id.passwordcomplete);
final EditText regemail = (EditText) findViewById(R.id.email);
String password = regpass.getText().toString();
password = md5(password);
param.add(new BasicNameValuePair("username", reguser.getText().toString()));
param.add(new BasicNameValuePair("password", password));
param.add(new BasicNameValuePair("email", regemail.getText().toString()));
try {
httpPost.setEntity(new UrlEncodedFormEntity(param));
HttpResponse httpRespose = httpClient.execute(httpPost);
HttpEntity httpEntity = httpRespose.getEntity();
InputStream in = httpEntity.getContent();
BufferedReader read = new BufferedReader(new InputStreamReader(in));
String isi= "";
String baris= "";
while((baris = read.readLine())!=null){
isi+= baris;
}
//Jika isi tidak sama dengan "null " maka akan tampil Toast "Berhasil" sebaliknya akan tampil "Gagal"
if(!isi.equals("null")){
Toast.makeText(this, "Berhasil", Toast.LENGTH_LONG).show();
}else{
Toast.makeText(this, "Gagal", Toast.LENGTH_LONG).show();
}
} catch (ClientProtocolException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
最佳答案
您需要在单独的线程中发出 HTTP 请求。你会很容易找到一个例子来证明这一点。看看这个:
关于java - 将数据从Android插入PHP文件,然后插入Mysql错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19259513/