首先,先建立用php寫出來的api,將書籍資料列表出來,寫的方式,就是先查詢出所有的書籍資料,再輸出成JSON格式的字串。再回傳給Android,再解析JSON格式後,再跟ListView結合在一起,顯示出資料。
下述為完整的php程式碼:
_db_Config.php
<?php
//連接資料庫的Server、帳號、密碼、資料庫
$db = new mysqli("localhost","root","password","bookinfo") or die("數據庫連接失敗!".$mysqli->errno);
//設定UTF8相關的選項
mysqli_query($db,"SET NAMES utf8");
mysqli_query($db,"CHARACTER SET utf8");
mysqli_query($db,"SET COLLATION_CONNECTION=utf8_general_ci");
mysqli_query($db,"SET CHARACTER_SET_CLIENT =utf8");
mysqli_query($db,"SET CHARACTER_SET_RESULTS =utf8");
mysqli_query($db,"SET CHARACTER_SET_SERVER = utf8");
mysqli_query($db,"SET character_set_connection=utf8");
?>
_api_getbookslist.php
<?php
//引用資料庫連接檔案
include("conn/_db_Config.php");
//查詢書籍資料列表的SQL語法
$sql = "select tbookinfo.*,ttaginfo.ctag_name from tbookinfo left join ttaginfo on tbookinfo.ctag_id = ttaginfo.ctag_id";
//執行SQL語法,並且將資料轉成array
$res = $db->query($sql);
$arytags = array();
while ($row = $res->fetch_assoc()) {
$arytags[] = $row;
}
//輸出成JSON字串,要加JSON_UNESCAPED_UNICODE,中文字才不會變成亂碼
echo json_encode($arytags, JSON_UNESCAPED_UNICODE);
?>
在網頁執行看看,沒有沒問題。
執行成功,回到Android,看看要如何呼叫此api,也是用之前文章用的方式,透過Volley物件,用GET的方式,回傳JSON字串。再解析成陣列後,再跟ListView元件結合。完整的程式碼,如下:
public class frm_book_list extends AppCompatActivity implements ListView.OnItemClickListener {
//宣告物件名稱。
private RequestQueue objqueue;
private final static String strurl = "http://192.168.63.231:8088/book/_api_getbookslist.php";
private ListView lsvbook;
ArrayList<String> arybooks;
private StringRequest getRequest;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_frm_book_list);
StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();
StrictMode.setThreadPolicy(policy);
//物件名稱跟Layout上的物件,產生連結。
lsvbook = (ListView) findViewById(R.id.lsvbook);
lsvbook.setOnItemClickListener(this);
arybooks=new ArrayList<>();
//設定Volley物件。
objqueue = Volley.newRequestQueue(this);
//實做Volley物件,在StringRequest的函式,預設值就是Request.Method.GET,可以省略。
//而strurl,就是要GET的API網址。
//最後,還要Override二個監聽的事件。
getRequest = new StringRequest(strurl, new Response.Listener<String>() {
@Override
public void onResponse(String response) {
//response,表示是回傳值,就是API要回傳的字串,也可以是JSON字串。
//宣告JSONArray時,要用try...catch包起來,不然會出現錯誤。
try{
//將JSON字串,放到JSONArray中。
JSONArray array = new JSONArray(response);
//解出JSON的資料,將所要的資料,再寫入陣列中。
for (int i = 0; i < array.length(); i++) {
JSONObject jsonObject = array.getJSONObject(i);
String strtagname = jsonObject.getString("cbook_name");
arybooks.add(strtagname);
}
}
catch(JSONException e) {
e.printStackTrace();
}
//將陣列跟Spinner物件連結在一起。
lsvbook.setAdapter(new ArrayAdapter<String>( frm_book_list.this, android.R.layout.simple_spinner_dropdown_item, arybooks));
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
//如果發生錯誤,就是回傳VolleyError,可以顯示是什麼錯誤。
}
});
//將getRequest物件加入Volley物件的queue中,執行跟API的溝通。
objqueue.add(getRequest);
}
@Override
public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
String strbookname = adapterView.getItemAtPosition(i).toString();
Intent it = new Intent();
it= new Intent(this,frm_book_edit.class);
it.putExtra("pname",strbookname);
startActivity(it);
this.finish();
}
public void prc_btnadd(View v)
{
Intent it = new Intent();
it= new Intent(this,frm_book_add.class);
startActivity(it);
this.finish();
}
//顯示訊息
public void prc_showmessage(String strmessage)
{
Toast objtoast = Toast.makeText(this,strmessage, Toast.LENGTH_SHORT);
objtoast.show();
}
}
執行模擬器的畫面。有列出書籍資料。
有關新增及點選ListView時,會觸發的事件及說明,後續,再解說。