将 POST 数据从 Android 应用程序发送到 PHP MySQL

Posted

技术标签:

【中文标题】将 POST 数据从 Android 应用程序发送到 PHP MySQL【英文标题】:Send POST data from Android application to PHP MySQL 【发布时间】:2016-03-30 11:45:30 【问题描述】:

我正在尝试向 WampServer 发送数据。我正在使用 HttpUrlConnection,但我不知道如何发送数据——可能是 JSON 格式或 XML。我已经使用内容值来保存要发送的变量的值,但我不知道如何将它们发送到 php 脚本中的 POST 方法。

这是 PHP 代码:

<?php 

if(isset($_POST['txtname'])&&isset($_POST['txtemail']))

    require ('config.php');
    $con=mysqli_connect($servername,$username,$password,$db);
    $txtname=$_POST['txtname'];
    $txtemail=$_POST['txtemail'];
    mysqli_query($con,"insert into users (name,email) values('$txtname','$txtemail') ");
    echo "Inserted";


?>

这是Java代码:

package com.subhi.addtoserver;

import android.app.ProgressDialog;
import android.content.ContentValues;
import android.os.AsyncTask;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

import java.io.IOException;
import java.io.OutputStream;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.ArrayList;
import java.util.List;

public class MainActivity extends AppCompatActivity 

   public EditText name,email;
    Button add;
    @Override
    protected void onCreate(Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        name=(EditText)findViewById(R.id.name);
        email=(EditText)findViewById(R.id.email);
        add=(Button)findViewById(R.id.add);
        add.setOnClickListener(new View.OnClickListener() 
            @Override
            public void onClick(View v) 

                InsertData task1 = new InsertData();
                String name1, email1;
                name1 = name.getText().toString();
                email1 = email.getText().toString();
                task1.execute("http://192.168.1.100/add/index.php", name1, email1);

            
        );
    


    private class InsertData extends AsyncTask<String,Void,Boolean>
    
        ProgressDialog dialog=new ProgressDialog(MainActivity.this);

        @Override
        protected Boolean doInBackground(String... urls) 

            for (String url: urls)
            

                try                       

                    ContentValues contentValues=new ContentValues();
                    contentValues.put("txtname",urls[1]);
                    contentValues.put("txtemail",urls[2]);

                    URL url1 =new URL(urls[0]);
                    HttpURLConnection urlConnection=(HttpURLConnection)url1.openConnection();
                    urlConnection.connect();

                 catch (MalformedURLException e) 
                    Toast.makeText(getApplicationContext(),e.toString(),Toast.LENGTH_LONG).show();;
                    e.printStackTrace();
                    return  false;
                 catch (IOException e) 
                    Toast.makeText(getApplicationContext(),e.toString(),Toast.LENGTH_LONG).show();;
                    e.printStackTrace();
                    return false;
                

            

            return true;
        

        @Override
        protected void onPreExecute() 

            dialog.setMessage("Sending Data....");
            dialog.show();
        

        @Override
        protected void onPostExecute(Boolean result) 
            if(result==true)
            

                Toast.makeText(getApplicationContext(),"Insert Success",Toast.LENGTH_LONG).show();;
            
            else 
                Toast.makeText(getApplicationContext(),"Insert Fail",Toast.LENGTH_LONG).show();;
            
            dialog.dismiss();
        
    

    @Override
    public boolean onCreateOptionsMenu(Menu menu) 
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.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();

        //noinspection SimplifiableIfStatement
        if (id == R.id.action_settings) 
            return true;
        

        return super.onOptionsItemSelected(item);
    

【问题讨论】:

看看这个答案中的代码:***.com/a/33031158/4409409 $txtname, $txtemail 这些到你想以 json 格式发回的变量?@ZygD @krishna muali 24,是的,我想将 txtname,txtemail 的值以 json 格式发送到服务器 【参考方案1】:

这就是你应该发送的方式。

echo json_encode(array("txtname"=>$txtname, "txtemail"=>'$txtemail'));

Android 中的客户端。 我希望你知道,如何从 json 中获取值。

【讨论】:

【参考方案2】:

这个 youtube URL 用于使用 SQL 服务器将数据 android 传递给 PHP。 网址:https://www.youtube.com/watch?v=D86beKXvjd0

试试这个

【讨论】:

以上是关于将 POST 数据从 Android 应用程序发送到 PHP MySQL的主要内容,如果未能解决你的问题,请参考以下文章

无法检测从android发送的php中的Post参数

使用 post 方法将数据从 java android 发送到网络服务器

从 Android Webview 获取 POST 数据

如何将多部分/表单数据从 android 发送到 Web 服务器?

如何使用异步http post从android studio发送数据到xampp并在真实设备中运行?

android如何将int和double作为namevaluepair作为http post发送