Android与PHP交互,Android传递JSON数据,PHP接受并保存数据

突然想到这样一个功能,用户使用某客户端登陆的时候,客户端做了以下两件事,一个是跳转页面,返回个人信息;第二个是将信息返回到服务器,服务器将数据保存在数据库中。这样一来用户的个人信息也就获取到了!

事不宜迟赶快实现吧!

正好我的SAE云豆还没有消耗完,我就打算用PHP做后台!

客户端与服务端传送现在比较流行传递Json字符串!(还好之前了解过Json),android将数据包装成Json格式,然后通过Httpclient发送给PHP后台,php根据属性名得到Json字符串,然后做出解析,最后保存(MySQL)流程就是这样。

技术分享

第一步:Android客户端封装Json格式数据

首先把你想要传送的数据封装成Json格式的数据,可以使用Json包或者Gson,我用的是Gson,我想要传送的是User对象,代码如下:

<span style="font-family:Microsoft YaHei;font-size:14px;">Gson gson = new Gson();
gson.toJson(user))
</span>
转换格式非常简单,不做太多介绍

第二步:在登录返回线程中写个异步方法(当然了,你想在任何时候调用异步都行,我就放在返回登录信息的时候触发异步任务),异步任务里调用Httpclient发送请求的方法,代码如下:

<span style="font-family:Microsoft YaHei;font-size:14px;">/**
	 * 
	 * 描述 向后台发送user数据
	 * @param user
	 */
	<span style="font-family:Times New Roman;">public static void SaveDataToPhp(User user){
		Gson gson = new Gson();
		String url = "http://bmhjqs.sinaapp.com/ChzuAppDate/chzu_user_save.php";  
		HttpPost httpRequest = new HttpPost(url);  

		List<NameValuePair> params = new ArrayList<NameValuePair>();  
		params.add(new BasicNameValuePair("userJson", gson.toJson(user)));  
		try {  
			HttpEntity httpEntity = new UrlEncodedFormEntity(params,"utf-8");  
			httpRequest.setEntity(httpEntity);  
			HttpClient httpClient = new DefaultHttpClient();  
			HttpResponse httpResponse = httpClient.execute(httpRequest);  
			if(httpResponse.getStatusLine().getStatusCode() == HttpStatus.SC_OK){  
				String result = EntityUtils.toString(httpResponse.getEntity());  
				Log.i("save", result);
			}else{  
			}  
		} catch (UnsupportedEncodingException e) {  
			e.printStackTrace();  
		} catch (ClientProtocolException e) {  
			e.printStackTrace();  
		} catch (IOException e) {  
			e.printStackTrace();  
		}  
	}</span>
</span>
此时,数据开始发送到PHP了

第三步:接收Json数据

在php中,通过参数Key来获取Value,代码如下:

<span style="font-family:Microsoft YaHei;font-size:14px;">//接受客户端传来的json数据
<span style="font-family:Times New Roman;">$json_string = $_POST ["userJson"];
$user = json_decode ( $json_user );

if (ini_get ( "magic_quotes_gpc" ) == "1") {
	$json_string = stripslashes ( $json_string );
}</span>
$user = json_decode ( $json_string, true );//必须加参数‘true’,否则PHP不认为$user是个数组</span>
需要注意的写在注释里了,到此,就可以通过array[key]的方法来获取值了;

第四步:保存数据

我将数据保存在SAE下的Mysql数据库,代码如下:

<span style="font-family:Microsoft YaHei;font-size:14px;">// 开始保存到数据库
<span style="font-family:Times New Roman;">$link = mysql_connect ( SAE_MYSQL_HOST_M . ':' . SAE_MYSQL_PORT, SAE_MYSQL_USER, SAE_MYSQL_PASS );
if ($link) {
	mysql_select_db ( SAE_MYSQL_DB, $link );
	//根据ID判断数据库里是否存在
	$isExit = "查询语句";	
	$result = mysql_query($isExit);
	if(mysql_num_rows($result) < 1){
		$sql = "插入语句...";
		mysql_query ( 'set names utf-8' );
		mysql_query ( $sql );
		echo 'STATE_OK';
	}else{
		echo 'STATE_EXIST';
	}
	mysql_close ( $link );
} else {
	echo 'STATE_DB_FAIL';
}</span></span>
第五步:测试


测试成功,数据可以正常的保存!





如果客观感觉有用的话,点个赞。。。我会更加的努力

如果有不对的地方还请指出,我会改正!

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。