請(qǐng)注意:這里提供的代碼只是為了使你能簡(jiǎn)單的連接Android項(xiàng)目和PHP,MySQL。你不能把它作為一個(gè)標(biāo)準(zhǔn)或者安全編程實(shí)踐。在生產(chǎn)環(huán)境中,理想情況下你需要避免使用任何可能造成潛在注入漏洞的代碼(比如MYSQL注入)。MYSQL注入是一個(gè)很大的話題,不可能用單獨(dú)的一篇文章來(lái)說(shuō)清楚,并且它也不在本文討論的范圍內(nèi),所以本文不以討論。
創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站設(shè)計(jì)制作、網(wǎng)站設(shè)計(jì)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的平利網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
1. 什么是WAMP Server
WAMP是Windows,Apache,MySQL和PHP,Perl,Python的簡(jiǎn)稱。WAMP是一個(gè)一鍵安裝的軟件,它為開(kāi)發(fā)PHP,MySQL Web應(yīng)用程序提供一個(gè)環(huán)境。安裝這款軟件你相當(dāng)于安裝了Apache,MySQL和PHP?;蛘?,你也可以使用XAMP。
2. 安裝和使用WAMP Server
你可以從http://www。wampserver。com/en/下載WAMP,安裝完成之后,可以從開(kāi)始-所有程序-WampServer-StartWampServer運(yùn)行該程序。
在瀏覽器中輸入來(lái)測(cè)試你的服務(wù)器是否安裝成功。同樣的,也可以打開(kāi)來(lái)檢驗(yàn)phpmyadmin是否安裝成功。
3. 創(chuàng)建和運(yùn)行PHP項(xiàng)目
現(xiàn)在,你已經(jīng)有一個(gè)能開(kāi)發(fā)PHP和MYSQL項(xiàng)目的環(huán)境了。打開(kāi)安裝WAMP Server的文件夾(在我的電腦中,是C:\wamp\),打開(kāi)www文件夾,為你的項(xiàng)目創(chuàng)建一個(gè)新的文件夾。你必須把項(xiàng)目中所有的文件放到這個(gè)文件夾中。
新建一個(gè)名為android_connect的文件夾,并新建一個(gè)php文件,命名為test.php,嘗試輸入一些簡(jiǎn)單的php代碼(如下所示)。輸入下面的代碼后,打開(kāi),你會(huì)在瀏覽器中看到“Welcome,I am connecting Android to PHP,MySQL”(如果沒(méi)有正確輸入,請(qǐng)檢查WAMP配置是否正確)
test.php
?php
echo"Welcome, I am connecting Android to PHP, MySQL";
?4. 創(chuàng)建MySQL數(shù)據(jù)庫(kù)和表
在本教程中,我創(chuàng)建了一個(gè)簡(jiǎn)單的只有一張表的數(shù)據(jù)庫(kù)。我會(huì)用這個(gè)表來(lái)執(zhí)行一些示例操作?,F(xiàn)在,請(qǐng)?jiān)跒g覽器中輸入,并打開(kāi)phpmyadmin。你可以用PhpMyAdmin工具創(chuàng)建數(shù)據(jù)庫(kù)和表。
創(chuàng)建數(shù)據(jù)庫(kù)和表:數(shù)據(jù)庫(kù)名:androidhive,表:product
CREATE DATABASE androidhive;
CREATE TABLE products(
pid int(11) primary key auto_increment,
name varchar(100) not null,
price decimal(10,2) not null,
description text,
created_at timestamp defaultnow(),
updated_at timestamp
);5. 用PHP連接MySQL數(shù)據(jù)庫(kù)
現(xiàn)在,真正的服務(wù)器端編程開(kāi)始了。新建一個(gè)PHP類來(lái)連接MYSQL數(shù)據(jù)庫(kù)。這個(gè)類的主要功能是打開(kāi)數(shù)據(jù)庫(kù)連接和在不需要時(shí)關(guān)閉數(shù)據(jù)庫(kù)連接。
新建兩個(gè)文件db_config.php,db_connect.php
db_config.php--------存儲(chǔ)數(shù)據(jù)庫(kù)連接變量
db_connect.php-------連接數(shù)據(jù)庫(kù)的類文件
db_config.php
?php
/*
* All database connection variables
*/
define('DB_USER', "root"); // db user
define('DB_PASSWORD', ""); // db password (mention your db password here)
define('DB_DATABASE', "androidhive"); // database name
define('DB_SERVER', "localhost"); // db serverdb_connect.php
?php
/**
* A class file to connect to database
*/
classDB_CONNECT {
// constructor
function__construct() {
// connecting to database
$this-connect();
}
// destructor
function__destruct() {
// closing db connection
$this-close();
}
/**
* Function to connect with database
*/
functionconnect() {
// import database connection variables
require_once__DIR__ . '/db_config.php';
// Connecting to mysql database
$con= mysql_connect(DB_SERVER, DB_USER, DB_PASSWORD) ordie(mysql_error());
// Selecing database
$db= mysql_select_db(DB_DATABASE) ordie(mysql_error()) ordie(mysql_error());
// returing connection cursor
return$con;
}
/**
* Function to close db connection
*/
functionclose() {
// closing db connection
mysql_close();
}
}
?怎么調(diào)用:當(dāng)你想連接MySQl數(shù)據(jù)庫(kù)或者執(zhí)行某些操作時(shí),可以這樣使用db_connect.php
$db= newDB_CONNECT(); // creating class object(will open database connection)
PHP是一種創(chuàng)建動(dòng)態(tài)交互性站點(diǎn)的服務(wù)器端腳本語(yǔ)言,優(yōu)勢(shì):PHP腳本語(yǔ)言應(yīng)用廣泛,開(kāi)源免費(fèi),最重要的是入門簡(jiǎn)單,容易掌握。PHP能夠生成動(dòng)態(tài)頁(yè)面內(nèi)容PHP能夠創(chuàng)建、打開(kāi)、讀取、寫入、刪除以及關(guān)閉服務(wù)器上的文件PHP能夠接收表單數(shù)據(jù)PHP能夠發(fā)送并取回cookiesPHP能夠添加、刪除、修改數(shù)據(jù)庫(kù)中的數(shù)據(jù)PHP能夠限制用戶訪問(wèn)網(wǎng)站中的某些頁(yè)面能夠運(yùn)行于各種平臺(tái),幾乎兼容所有WEB服務(wù)器,支持多種數(shù)據(jù)庫(kù)1.我們想要運(yùn)行PHP,首先要有個(gè)web服務(wù)器,一般可以在本地部署一個(gè)服務(wù)器用來(lái)測(cè)試。所以需要下載個(gè)XAMPP,我們?cè)诎俣人阉鱝pache friends,直接打開(kāi)第一個(gè)鏈接,然后毫不猶豫的下載最新版本(PHP7.0.9),下載后執(zhí)行安裝。2.2.現(xiàn)在來(lái)配置XAMPP來(lái)部署一個(gè)本地服務(wù)器,打開(kāi)只需要啟用Apache服務(wù),下面我就啟動(dòng)成功了。如果啟用不成功,Port(s)沒(méi)有數(shù)據(jù)顯示,就證明你監(jiān)聽(tīng)的PC端口被占用,你可以在Config的里第一個(gè)選項(xiàng)進(jìn)行監(jiān)聽(tīng)端口的更改,找到記事本里的Listen 8080命令改后綴,這里我把監(jiān)聽(tīng)端口改成空閑的8080了。3.下面來(lái)打開(kāi)Dreamweaver建一個(gè)服務(wù)器站點(diǎn)。站點(diǎn)配置:本地站點(diǎn)文件夾一定要選擇你裝Xampp路徑的htdocs的目錄里。4.添加服務(wù)器配置:這樣站點(diǎn)就設(shè)置好了,然后在站點(diǎn)文件夾創(chuàng)建server.php,腳本如下?php //設(shè)置頁(yè)面內(nèi)容是html編碼格式是utf-8 //header("Content-Type: text/plain;charset=utf-8"); header('Access-Control-Allow-Origin:*'); header('Access-Control-Allow-Methods:POST,GET'); header('Access-Control-Allow-Credentials:true'); header("Content-Type: application/json;charset=utf-8"); //header("Content-Type: text/xml;charset=utf-8"); //header("Content-Type: text/html;charset=utf-8"); //header("Content-Type: application/javascript;charset=utf-8"); //定義一個(gè)多維數(shù)組,包含員工的信息,每條員工信息為一個(gè)數(shù)組 $staff = array ( array("name" = "喬布斯", "number" = "101", "sex" = "男", "job" = "IOS開(kāi)發(fā)工程師"), array("name" = "比爾蓋茨", "number" = "102", "sex" = "男", "job" = "微軟開(kāi)發(fā)工程師"), array("name" = "陳美麗", "number" = "103", "sex" = "女", "job" = "安卓開(kāi)發(fā)工程師"), array("name" = "黃力", "number" = "104", "sex" = "男", "job" = "Java開(kāi)發(fā)工程師"), array("name" = "車神", "number" = "105", "sex" = "男", "job" = "游戲開(kāi)發(fā)工程師"), array("name" = "測(cè)試貓", "number" = "106", "sex" = "男", "job" = "web前端開(kāi)發(fā)工程師") ); //判斷如果是get請(qǐng)求,則進(jìn)行搜索;如果是POST請(qǐng)求,則進(jìn)行新建 //$_SERVER是一個(gè)超全局變量,在一個(gè)腳本的全部作用域中都可用,不用使用global關(guān)鍵字 //$_SERVER["REQUEST_METHOD"]返回訪問(wèn)頁(yè)面使用的請(qǐng)求方法 if ($_SERVER["REQUEST_METHOD"] == "GET") { search(); } elseif ($_SERVER["REQUEST_METHOD"] == "POST"){ create(); } //通過(guò)員工編號(hào)搜索員工 function search(){ //檢查是否有員工編號(hào)的參數(shù) //isset檢測(cè)變量是否設(shè)置;empty判斷值為否為空 //超全局變量 $_GET 和 $_POST 用于收集表單數(shù)據(jù) if (!isset($_GET["number"]) empty($_GET["number"])) { echo '{"success":false,"msg":"參數(shù)錯(cuò)誤"}'; return; } //函數(shù)之外聲明的變量擁有 Global 作用域,只能在函數(shù)以外進(jìn)行訪問(wèn)。 //global 關(guān)鍵詞用于訪問(wèn)函數(shù)內(nèi)的全局變量 global $staff; //獲取number參數(shù) $number = $_GET["number"]; $result = '{"success":false,"msg":"沒(méi)有找到員工。"}'; //遍歷$staff多維數(shù)組,查找key值為number的員工是否存在,如果存在,則修改返回結(jié)果 foreach ($staff as $value) { if ($value["number"] == $number) { $result = '{"success":true,"msg":"找到員工:?jiǎn)T工編號(hào):' . $value["number"] . ',員工姓名:' . $value["name"] . ',員工性別:' . $value["sex"] . ',員工職位:' . $value["job"] . '"}'; break; } } echo $result; } //創(chuàng)建員工 function create(){ //判斷信息是否填寫完全 if (!isset($_POST["name"]) empty($_POST["name"]) !isset($_POST["number"]) empty($_POST["number"]) !isset($_POST["sex"]) empty($_POST["sex"]) !isset($_POST["job"]) empty($_POST["job"])) { echo '{"success":false,"msg":"參數(shù)錯(cuò)誤,員工信息填寫不全"}'; return; } //TODO: 獲取POST表單數(shù)據(jù)并保存到數(shù)據(jù)庫(kù) //提示保存成功 echo '{"success":true,"msg":"員工:' . $_POST["name"] . ' 信息保存成功!"}'; } ? 我們可以在server.php文件數(shù)組$staff里的數(shù)據(jù)進(jìn)行查詢,并且可以實(shí)現(xiàn)添加數(shù)據(jù)的功能,下面來(lái)創(chuàng)建demo.htmlstyle body,input,button,select,h1{ font-size:20px; line-height:18px; } /style script window.onload=function(){ document.getElementById("search").onclick=function(){//查詢數(shù)據(jù) //發(fā)送Ajax查詢請(qǐng)求并處理 var request=new XMLHttpRequest(); //open("方法(GET查詢,POST添加)","打開(kāi)的文件數(shù)據(jù)",處理方式(同步為false異步為true,不填默認(rèn)為true)); request.open("GET","server.php?number="+document.getElementById('keyword').value); request.send(); request.onreadystatechange=function(){ if(request.readyState===4){//當(dāng)服務(wù)器請(qǐng)求完成 if(request.status===200){//status==200為服務(wù)器請(qǐng)求成功 var data=JSON.parse(request.responseText); if(data.success){//數(shù)據(jù)填寫符合要求 document.getElementById('searchResult').innerHTML=data.msg; }else{//數(shù)據(jù)填寫不符號(hào)要求 document.getElementById('searchResult').innerHTML="出現(xiàn)錯(cuò)誤:"+data.msg; } }else{//服務(wù)器請(qǐng)求失敗 alert("發(fā)生錯(cuò)誤:"+request.status); } } } } document.getElementById("save").onclick=function(){//添加數(shù)據(jù) //發(fā)送Ajax添加數(shù)據(jù)請(qǐng)求并處理 var request=new XMLHttpRequest(); //open("方法(GET查詢,POST添加)","打開(kāi)的文件數(shù)據(jù)",處理方式(同步為false異步為true,不填默認(rèn)為true));; request.open("POST","server.php"); //定義data取得用戶所填寫的數(shù)據(jù),并且send(data)到服務(wù)器 var data="name="+document.getElementById("staffName").value +"number="+document.getElementById("staffNumber").value +"sex="+document.getElementById("staffSex").value +"job="+document.getElementById("staffJob").value; request.setRequestHeader("Content-Type","application/x-www-form-urlencoded");//在POST方法里必寫,否則添加數(shù)據(jù)不起作用 request.send(data); request.onreadystatechange=function(){ if(request.readyState===4){//當(dāng)服務(wù)器請(qǐng)求完成 if(request.status===200){//status==200為服務(wù)器請(qǐng)求成功 var data=JSON.parse(request.responseText); if(data.success){//數(shù)據(jù)填寫符合要求 document.getElementById('createResult').innerHTML=data.msg; }else{//數(shù)據(jù)填寫不符合要求 document.getElementById('createResult').innerHTML="出現(xiàn)錯(cuò)誤:"+data.msg; } }else{//服務(wù)器請(qǐng)求失敗 alert("發(fā)生錯(cuò)誤:"+request.status); } } } } } /script body h1員工查詢/h1 label請(qǐng)輸入員工編號(hào):/label input type="text" id="keyword"/ button id="search"查詢/button p id="searchResult"/p h1員工創(chuàng)建/h1 label請(qǐng)輸入員工姓名:/label input type="text" id="staffName"/br label請(qǐng)輸入員工編號(hào):/label input type="text" id="staffNumber"/br label請(qǐng)輸入員工性別:/label select id="staffSex" option男/option option女/option /selectbr label請(qǐng)輸入員工職位:/label input type="text" id="staffJob"/br button id="save"保存/button p id="createResult"/p /body 以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
這個(gè)要看你的架構(gòu)吧
你是使用bs呢,還是cs呢?
可以定時(shí)查詢一下,有更新就啟動(dòng)連接更新
可以使用ajax,注意要客戶端瀏覽器支持才行
我們先來(lái)看一個(gè)簡(jiǎn)單的Android app例子(這里是一個(gè)商品存貨清單項(xiàng)目),在Android程序中,我們可以訪問(wèn)(call)PHP腳本來(lái)執(zhí)行簡(jiǎn)單的CRUD操作(創(chuàng)建,讀取,更新,刪除)。為了使你對(duì)它的體系結(jié)構(gòu)有一個(gè)大概的了解,這里先說(shuō)一下它是怎么工作的。首先你的Android項(xiàng)目訪問(wèn)(call)PHP腳本來(lái)執(zhí)行一條數(shù)據(jù)操作,我們稱它為“創(chuàng)建”。然后PHP腳本連接MySQL數(shù)據(jù)庫(kù)來(lái)執(zhí)行這個(gè)操作。這樣,數(shù)據(jù)從Android程序流向PHP腳本,最終存儲(chǔ)在MySQL數(shù)據(jù)庫(kù)中。
好了,讓我們來(lái)深入的看一下。
請(qǐng)注意:這里提供的代碼只是為了使你能簡(jiǎn)單的連接Android項(xiàng)目和PHP,MySQL。你不能把它作為一個(gè)標(biāo)準(zhǔn)或者安全編程實(shí)踐。在生產(chǎn)環(huán)境中,理想情況下你需要避免使用任何可能造成潛在注入漏洞的代碼(比如MYSQL注入)。MYSQL注入是一個(gè)很大的話題,不可能用單獨(dú)的一篇文章來(lái)說(shuō)清楚,并且它也不在本文討論的范圍內(nèi),所以本文不以討論。
1. 什么是WAMP Server
WAMP是Windows,Apache,MySQL和PHP,Perl,Python的簡(jiǎn)稱。WAMP是一個(gè)一鍵安裝的軟件,它為開(kāi)發(fā)PHP,MySQL Web應(yīng)用程序提供一個(gè)環(huán)境。安裝這款軟件你相當(dāng)于安裝了Apache,MySQL和PHP。或者,你也可以使用 XAMP 。
2. 安裝和使用WAMP Server
在瀏覽器中輸入 來(lái)測(cè)試你的服務(wù)器是否安裝成功。同樣的,也可以打開(kāi) 來(lái)檢驗(yàn)phpmyadmin是否安裝成功。
3. 創(chuàng)建和運(yùn)行PHP項(xiàng)目
現(xiàn)在,你已經(jīng)有一個(gè)能開(kāi)發(fā)PHP和MYSQL項(xiàng)目的環(huán)境了。打開(kāi)安裝WAMP Server的文件夾(在我的電腦中,是C:\wamp\),打開(kāi)www文件夾,為你的項(xiàng)目創(chuàng)建一個(gè)新的文件夾。你必須把項(xiàng)目中所有的文件放到這個(gè)文件夾中。
新建一個(gè)名為android_connect的文件夾,并新建一個(gè)php文件,命名為test.php,嘗試輸入一些簡(jiǎn)單的php代碼(如下所示)。輸入下面的代碼后,打開(kāi) ,你會(huì)在瀏覽器中看到“Welcome,I am connecting Android to PHP,MySQL”(如果沒(méi)有正確輸入,請(qǐng)檢查WAMP配置是否正確)
test.php
?php
echo"Welcome, I am connecting Android to PHP, MySQL";
?
4. 創(chuàng)建MySQL數(shù)據(jù)庫(kù)和表
在本教程中,我創(chuàng)建了一個(gè)簡(jiǎn)單的只有一張表的數(shù)據(jù)庫(kù)。我會(huì)用這個(gè)表來(lái)執(zhí)行一些示例操作?,F(xiàn)在,請(qǐng)?jiān)跒g覽器中輸入 ,并打開(kāi) phpmyadmin。 你可以用PhpMyAdmin工具創(chuàng)建數(shù)據(jù)庫(kù)和表。
創(chuàng)建數(shù)據(jù)庫(kù)和表:數(shù)據(jù)庫(kù)名:androidhive,表:product
CREATE DATABASE androidhive;
CREATE TABLE products(
pid int(11) primary key auto_increment,
name varchar(100) not null,
price decimal(10,2) not null,
description text,
created_at timestamp defaultnow(),
updated_at timestamp
);
5. 用PHP連接MySQL數(shù)據(jù)庫(kù)
現(xiàn)在,真正的服務(wù)器端編程開(kāi)始了。新建一個(gè)PHP類來(lái)連接MYSQL數(shù)據(jù)庫(kù)。這個(gè)類的主要功能是打開(kāi)數(shù)據(jù)庫(kù)連接和在不需要時(shí)關(guān)閉數(shù)據(jù)庫(kù)連接。
新建兩個(gè)文件 db_config.php,db_connect.php
db_config.php-------- 存儲(chǔ)數(shù)據(jù)庫(kù)連接變量
db_connect.php------- 連接數(shù)據(jù)庫(kù)的類文件
db_config.php
?php
/*
* All database connection variables
*/
define('DB_USER', "root"); // db user
define('DB_PASSWORD', ""); // db password (mention your db password here)
define('DB_DATABASE', "androidhive"); // database name
define('DB_SERVER', "localhost"); // db server
db_connect.php
?php
/**
* A class file to connect to database
*/
classDB_CONNECT {
// constructor
function__construct() {
// connecting to database
$this-connect();
}
// destructor
function__destruct() {
// closing db connection
$this-close();
}
/**
* Function to connect with database
*/
functionconnect() {
// import database connection variables
require_once__DIR__ . '/db_config.php';
// Connecting to mysql database
$con= mysql_connect(DB_SERVER, DB_USER, DB_PASSWORD) ordie(mysql_error());
// Selecing database
$db= mysql_select_db(DB_DATABASE) ordie(mysql_error()) ordie(mysql_error());
// returing connection cursor
return$con;
}
/**
* Function to close db connection
*/
functionclose() {
// closing db connection
mysql_close();
}
}
?
怎么調(diào)用 :當(dāng)你想連接MySQl數(shù)據(jù)庫(kù)或者執(zhí)行某些操作時(shí),可以這樣使用db_connect.php
$db= newDB_CONNECT(); // creating class object(will open database connection)
6. 使用PHP執(zhí)行基本CRUD操作
在這部分,我將講述使用PHP對(duì)MySQL數(shù)據(jù)庫(kù)執(zhí)行基本CRUD(創(chuàng)建,讀取,更新,刪除)操作。
如果你是PHP和MySQL新手,我建議你可以先學(xué)習(xí) PHP 和 SQL 基礎(chǔ)知識(shí)。
6. a)在MYSQL中新建一行(創(chuàng)建一行新的產(chǎn)品)
在你的PHP項(xiàng)目中新建一個(gè)php文件,命名為create_product.php,并輸入以下代碼。該文件主要實(shí)現(xiàn)在products表中插入一個(gè)新的產(chǎn)品。
在下面的代碼我使用POST來(lái)讀取產(chǎn)品數(shù)據(jù)并把他們存儲(chǔ)在products表中。
最后我會(huì)輸出一些JSON返回值,以便返回給客戶端(Android項(xiàng)目)