Android 简明教程

Android - PHP/MYSQL

在本章中,我们将解释如何将 PHP 和 MYSQL 与您的 Android 应用程序集成在一起。如果您有一个网络服务器,并且您希望在您的 Android 应用程序上访问其数据,这是非常有用的。

MYSQL 作为网络服务器上的数据库使用,PHP 用于从数据库中获取数据。我们的应用程序将与 PHP 页面进行必要的参数通信,PHP 将联系 MYSQL 数据库,获取结果并向我们返回结果。

PHP - MYSQL

Creating Database

使用此简单脚本来轻松创建 MYSQL 数据库。 CREATE DATABASE 语句创建数据库。

<?php
   $con=mysqli_connect("example.com","username","password");
   $sql="CREATE DATABASE my_db";
   if (mysqli_query($con,$sql)) {
      echo "Database my_db created successfully";
   }
?>

Creating Tables

一旦创建了数据库,就是时候在数据库中创建一些表了。 CREATE TABLE 语句创建数据库。

<?php
   $con=mysqli_connect("example.com","username","password","my_db");
   $sql="CREATE TABLE table1(Username CHAR(30),Password CHAR(30),Role CHAR(30))";
   if (mysqli_query($con,$sql)) {
      echo "Table have been created successfully";
   }
?>

Inserting Values in tables

当数据库和表创建好后,现在是时候将一些数据插入表中了。 Insert Into 语句创建数据库。

<?php
   $con=mysqli_connect("example.com","username","password","my_db");
   $sql="INSERT INTO table1 (FirstName, LastName, Age) VALUES ('admin', 'admin','adminstrator')";
   if (mysqli_query($con,$sql)) {
      echo "Values have been inserted successfully";
   }
?>

PHP - GET and POST methods

PHP 还用于在创建后从 mysql 数据库中获取记录。为了获取记录,必须将一些信息传递给 PHP 页面,说明要获取什么记录。

传递信息的第一种方法是通过 GET 方法,其中使用了 $_GET 命令。变量在 url 中传递,并且提取记录。它的语法如下所示:

<?php
   $con=mysqli_connect("example.com","username","password","database name");

   if (mysqli_connect_errno($con)) {
      echo "Failed to connect to MySQL: " . mysqli_connect_error();
   }

   $username = $_GET['username'];
   $password = $_GET['password'];
   $result = mysqli_query($con,"SELECT Role FROM table1 where Username='$username'
      and Password='$password'");
   $row = mysqli_fetch_array($result);
   $data = $row[0];

   if($data){
      echo $data;
   }
   mysqli_close($con);
?>

第二种方法是使用 POST 方法。上述脚本的唯一更改是用 $_POST 替换 $_GET。在 Post 方法中,变量不会通过 URL 传递。

Android - Connecting MYSQL

Connecting Via Get Method

有两种方法可以通过 PHP 页面连接到 MYSQL。第一个称为 Get method 。我们将使用 HttpGetHttpClient 类连接。它们的语法如下所示:

URL url = new URL(link);
HttpClient client = new DefaultHttpClient();
HttpGet request = new HttpGet();
request.setURI(new URI(link));

之后,您需要调用 HttpClient 类的 execute 方法并在 HttpResponse 对象中接收它。之后,您需要打开流以接收数据。

HttpResponse response = client.execute(request);
BufferedReader in = new BufferedReader
(new InputStreamReader(response.getEntity().getContent()));

Connecting Via Post Method

在 Post 方法中,将使用 URLEncoderURLConnection 类。urlencoder 将对传入变量的信息进行编码。其语法如下所示:

URL url = new URL(link);
String data  = URLEncoder.encode("username", "UTF-8")
+ "=" + URLEncoder.encode(username, "UTF-8");
data += "&" + URLEncoder.encode("password", "UTF-8")
+ "=" + URLEncoder.encode(password, "UTF-8");
URLConnection conn = url.openConnection();

您需要做的最后一件事是将此数据写入链接。写入后,您需要打开流以接收已响应的数据。

OutputStreamWriter wr = new OutputStreamWriter(conn.getOutputStream());
wr.write( data );
BufferedReader reader = new BufferedReader(new
InputStreamReader(conn.getInputStream()));

Example

以下示例是通过 PHP 页面将 Android 应用程序与 MYSQL 数据库连接的完整示例。它创建了一个基本应用程序,允许您使用 GET 和 POST 方法登录。

PHP - MYSQL part

在此示例中,已在 000webhost.com 上创建了一个名为 temp 的数据库。在该数据库中,已创建一个名为 table1 的表。此表有三个字段。(用户名,密码,角色)。该表只有一条记录,即 (“admin”、“admin”、“administrator”)。

下面给出了通过 post 方法获取参数的 php 页面。

<?php
   $con=mysqli_connect("mysql10.000webhost.com","username","password","db_name");

   if (mysqli_connect_errno($con)) {
      echo "Failed to connect to MySQL: " . mysqli_connect_error();
   }

   $username = $_POST['username'];
   $password = $_POST['password'];
   $result = mysqli_query($con,"SELECT Role FROM table1 where
   Username='$username' and Password='$password'");
   $row = mysqli_fetch_array($result);
   $data = $row[0];

   if($data){
      echo $data;
   }

   mysqli_close($con);
?>

Android Part

要测试此示例,您需要在已连接 wifi 互联网的实际设备上运行它。

Steps

Description

1

您将使用 Android studio IDE 创建一个 Android 应用程序,并将其命名为 PHPMYSQL,package 为 com.example.phpmysql。

2

修改 src/MainActivity.java 文件以添加 Activity 代码。

3

创建 src/SiginActivity.java 文件以添加 PHPMYSQL 代码。

4

修改布局 XML 文件 res/layout/activity_main.xml,如有需要,则添加任何 GUI 组件。

5

修改 res/values/string.xml 文件并添加必要的字符串组件。

6

修改 AndroidManifest.xml 以添加必要的权限。

7

运行该应用程序,选择一个正在运行的安卓设备,并在该设备上安装应用程序并验证结果。

以下是 src/com.example.phpmysql/MainActivity.java 的内容。

package com.example.phpmysql;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;
import android.widget.TextView;

public class MainActivity extends Activity {

   private EditText usernameField,passwordField;
   private TextView status,role,method;

   @Override
   protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);

      usernameField = (EditText)findViewById(R.id.editText1);
      passwordField = (EditText)findViewById(R.id.editText2);

      status = (TextView)findViewById(R.id.textView6);
      role = (TextView)findViewById(R.id.textView7);
      method = (TextView)findViewById(R.id.textView9);
   }



   public void login(View view){
      String username = usernameField.getText().toString();
      String password = passwordField.getText().toString();
      method.setText("Get Method");
      new SigninActivity(this,status,role,0).execute(username,password);

   }

   public void loginPost(View view){
      String username = usernameField.getText().toString();
      String password = passwordField.getText().toString();
      method.setText("Post Method");
      new SigninActivity(this,status,role,1).execute(username,password);
   }
}

以下是 src/com.example.phpmysql/SigninActivity.java 的内容。

package com.example.phpmysql;

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.net.URI;
import java.net.URL;
import java.net.URLConnection;
import java.net.URLEncoder;

import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.DefaultHttpClient;

import android.content.Context;
import android.os.AsyncTask;
import android.widget.TextView;

public class SigninActivity  extends AsyncTask{
   private TextView statusField,roleField;
   private Context context;
   private int byGetOrPost = 0;

   //flag 0 means get and 1 means post.(By default it is get.)
   public SigninActivity(Context context,TextView statusField,TextView roleField,int flag) {
      this.context = context;
      this.statusField = statusField;
      this.roleField = roleField;
      byGetOrPost = flag;
   }

   protected void onPreExecute(){
   }

   @Override
   protected String doInBackground(String... arg0) {
      if(byGetOrPost == 0){ //means by Get Method

         try{
            String username = (String)arg0[0];
            String password = (String)arg0[1];
            String link = "http://myphpmysqlweb.hostei.com/login.php?username="+username+"& password="+password;

            URL url = new URL(link);
            HttpClient client = new DefaultHttpClient();
            HttpGet request = new HttpGet();
            request.setURI(new URI(link));
            HttpResponse response = client.execute(request);
            BufferedReader in = new BufferedReader(new
               InputStreamReader(response.getEntity().getContent()));

            StringBuffer sb = new StringBuffer("");
            String line="";

            while ((line = in.readLine()) != null) {
               sb.append(line);
               break;
            }

            in.close();
            return sb.toString();
         } catch(Exception e){
            return new String("Exception: " + e.getMessage());
         }
      } else{
         try{
            String username = (String)arg0[0];
            String password = (String)arg0[1];

            String link="http://myphpmysqlweb.hostei.com/loginpost.php";
            String data  = URLEncoder.encode("username", "UTF-8") + "=" +
               URLEncoder.encode(username, "UTF-8");
            data += "&" + URLEncoder.encode("password", "UTF-8") + "=" +
               URLEncoder.encode(password, "UTF-8");

            URL url = new URL(link);
            URLConnection conn = url.openConnection();

            conn.setDoOutput(true);
            OutputStreamWriter wr = new OutputStreamWriter(conn.getOutputStream());

            wr.write( data );
            wr.flush();

            BufferedReader reader = new BufferedReader(new
               InputStreamReader(conn.getInputStream()));

            StringBuilder sb = new StringBuilder();
            String line = null;

            // Read Server Response
            while((line = reader.readLine()) != null) {
               sb.append(line);
               break;
            }

            return sb.toString();
         } catch(Exception e){
            return new String("Exception: " + e.getMessage());
         }
      }
   }

   @Override
   protected void onPostExecute(String result){
      this.statusField.setText("Login Successful");
      this.roleField.setText(result);
   }
}