如何跟PHP Server溝通-傳送JSON

如何跟PHP Server溝通-傳送JSON

電子書

如果您需要更詳細的範例
更完整的說明可以取得電子書來學習這個單元
http://glarethink.weebly.com/php2android.html

其他相關章節

情境

如果要接收 PHP 的 JSON 該怎麼做?
根據如何跟PHP Server溝通可以得知利用Volley就可以拉回所需字串, 但是如果是要用json呢?
其實道理相同, Json本身也是一個字串, 只是這邊可以透過一個簡單的工具來幫助你轉換,
可以參考如何使用Gson

完整程式碼

你可以到 GitHub 上面觀看或者下載完整程式碼

程式碼說明

一開始先寫入一個 PHP
一樣放在 XAMPP 的 htdocs 下面

<?php
echo json_encode(array('id' => '123', 'data' => 'abc'));
?>

然後開一個新專案, 透過 Gradle 將 Volley 跟 Gson 導入

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    testCompile 'junit:junit:4.12'
    compile 'com.android.support:appcompat-v7:23.1.0'
    compile 'com.mcxiaoke.volley:library:1.0.+'
}

權限記得加

<uses-permission android:name="android.permission.INTERNET" />

跟在如何跟 PHP Server 溝通相同建立一個 Button
按下去以後就去跟 Server 要資料

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:paddingBottom="@dimen/activity_vertical_margin"
    tools:context=".MainActivity">

    <TextView
        android:id="@+id/msg"
        android:text="Hello World!"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"/>
    <Button
        android:layout_below="@id/msg"
        android:text="get msg from server"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/get_msg"/>
</RelativeLayout>

MainActivity.java 部分

public class MainActivity extends AppCompatActivity {
    private RequestQueue mQueue;
    private final static String mUrl = "http://192.168.56.1/get_json.php";
    private TextView msg;
    private Button mGetMsgButton;
    private StringRequest getRequest;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        msg = (TextView) findViewById(R.id.msg);
        mGetMsgButton = (Button) findViewById(R.id.get_msg);
        mQueue = Volley.newRequestQueue(this);
        getRequest = new StringRequest(mUrl,
                new Response.Listener<String>() {
                    @Override
                    public void onResponse(String s) {
                        msg.setText(s);
                    }
                },
                new Response.ErrorListener() {

                    @Override
                    public void onErrorResponse(VolleyError volleyError) {
                        msg.setText(volleyError.getMessage());
                    }
                });
        mGetMsgButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                mQueue.add(getRequest);
            }
        });
    }
}

可是出來的畫面卻是 JSON 格式









所以我們必須利用 Gson 將其轉換
先宣告一個 MyJson 的類別

public class MyJson {
    @SerializedName("id")
    private String myId;
    @SerializedName("data")
    private String myName;

    public String getMyId() {
        return myId;
    }

    public void setMyId(String myId) {
        this.myId = myId;
    }

    public String getMyName() {
        return myName;
    }

    public void setMyName(String myName) {
        this.myName = myName;
    }
}

接著將 Volley 回來的部分稍微改一下

Gson gson = new Gson();
MyJson json = gson.fromJson(s, MyJson.class);
msg.setText("My id is :" + json.getMyId() + ", My name is :" + json.getMyName());

那就可以看到畫面長這樣, 成功解析 JSON 字串





這樣就是一個簡單的從 PHP Server 接收 JSON 的範例了