java - 将数据从Android插入PHP文件,然后插入Mysql错误

标签 java android mysql android-intent

我正在使用 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 请求。你会很容易找到一个例子来证明这一点。看看这个:

Thread HTTP

关于java - 将数据从Android插入PHP文件,然后插入Mysql错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19259513/

相关文章:

java - 为什么我的 JavaFX 应用程序不显示 Web 浏览器?

android - 从 NavigationDrawer 中选择时如何防止 fragment 重新创建?

mysql - 错误 1054 (42S22) : Unknown column 'year' in 'where clause'

php - 从数据库中检索数据的最有效算法

java - 将 MySQL 查询转换为 Java 中的实体管理器查询

java - Java 排序双向链表

java - 在 Java Applet 中显示网页

java - Jersey 在 Restful 服务中将 HashMap 序列化为 json 最简单的方法是什么?

java - fragment 或 Activity 中的抽屉导航?

Android 应用程序使用 Socket.io 连接到 Node.js 服务器