PHP接收json 并将接收数据插入数据库的实现代码

PHP接收json 并将接收数据插入数据库的实现代码,第1张

最近有一个需求,前端向后台提交json,后台解析并且将提交的值插入数据库中,

难点

1、php解析json(这个不算难点了,网上实例一抓一大把)

2、解析json后,php怎样拿到该拿的值

<?php

require

('connect.php')

/*

本例用到的数据:

post_array={"order_id":"0022015112305010013","buyer_id":"2","seller_id":"1","all_price":"100.00","json_list":[{"product_id":"3","product_number":"3"},{"product_id":"8","product_number":"2"},{"product_id":"10","product_number":"4"}]}

*/

$post_array=$_POST['post_array']

//--解析Json,获取对应的变量值

$obj=json_decode($post_array,TRUE)

$order_id

=

$obj['order_id']

$buyer_id

=

$obj['buyer_id']

$seller_id

=

$obj['seller_id']

$all_price

=

$obj['all_price']

$i=0//循环变量

//--得到Json_list数组长度

$num=count($obj["json_list"])

//--遍历数组,将对应信息添加入数据库

for

($i$i<$num$i++)

{

$list_product_id[]=$obj["json_list"][$i]["product_id"]

$list_product_number[]=$obj["json_list"][$i]["product_number"]

$insert_order_product_sql="INSERT

INTO

tbl_order_product

(order_id,product_id,product_number)

VALUES

(?,?,?)"

$result

=

$sqlconn

->

prepare($insert_order_product_sql)

$result

->

bind_param("sss",

$order_id,$list_product_id[$i],$list_product_number[$i])

$result->execute()

}

//--添加订单信息

$insert_order_sql="INSERT

INTO

tbl_order

(order_id,buyer_id,seller_id,all_price)

VALUES

(?,?,?,?)"

$result=$sqlconn->prepare($insert_order_sql)

$result->bind_param("ssss",$order_id,$buyer_id,$seller_id,$all_price)

$result->execute()

$result

->

close()

$sqlconn

->

close()

?>

投稿者信息

昵称:

Hola

Email:

jamcistos@outlook.com

在PHP中解析JSON主要用到json_encode和json_decode两个PHP

JSON函数,比PHP解析XML方便很多,下面详细介绍下PHP

JSON的使用。

JSON基础介绍

JSON(JavaScript

Object

Notation)

是一种轻量级的数据交换格式。

JSON主要有两种结构:

“名称/值”对的集合,在PHP中可以理解为关联数组

(associative

array)。

值的有序列表(An

ordered

list

of

values)。在PHP中可以理解为普通数组(array)。

对象是一个无序的“‘名称/值'对”集合。一个对象以“{”(左括号)开始,“}”(右括号)结束。每个“名称”后跟一个“:”(冒号);“‘名称/值'

对”之间使用“,”(逗号)分隔。

数组是值(value)的有序集合。一个数组以“[”(左中括号)开始,“]”(右中括号)结束。值之间使用“,”(逗号)分隔。值(value)可以是双引号括起来的字符串(string)、数值(number)、true、false、

null、对象(object)或者数组(array)。这些结构可以嵌套。

我目前对JSON的理解更偏向于数组,类似于PHP中的关联数组,你可以将PHP数组转换为JSON格式。

更多JSON的介绍请参考JSON官网和IBM关于JSON的介绍

PHP

JSON解析实例

PHP5.2开始已经将JSON作为PHP扩展的一部分,所以并不需要另外安装JSON。另外为了保证下面的PHP

JSON实例不出现中文乱码,请保证你的编码格式为UTF8。

JSON是Javascript的一部分,首先我们看下Javascript中如何定义JSON

复制代码

代码如下:

var

json_obj

=

{'WebName':'PHP网站开发教程网'}

alert(json_obj.WebName)

var

json_arr

=[{'WebName':'PHP网站开发教程网','WebSite':'http://www.jb51.net'},{'ArtTitle':'PHP

JSON实例讲解'}]

alert(json_arr[1].ArtTitle)

var

php_json

=

[['PHP网站开发教程网','http://www.jb51.net'],['文章标题','PHP

JSON实例讲解']]

alert(php_json[1][0])

在这段JSON实例代码中我构建了所有的JSON形式,

第1行,定义了JSON以对象形式存在

第4行,定义了JSON以数组形式存在,嵌套了JSON对象,所以有点类似于PHP的关联数组,其实仍然是对象。

第7行,定了JSON以普通数组形式存在。

注意:由于Javascript是区分大小写的,所以访问JSON关联数组对象时注意key的大小写问题。

PHP与JSON格式数据交互时,第一步需要将PHP数组转换为JSON格式的数据,可使用PHP5自带的json_encode函数,当PHP解析传递过来的JSON格式数据时需要使用json_decode函数进行解析转换为PHP数组,PHP转换并解析JSON数据的实例代码如下

复制代码

代码如下:

<?php

$json_arr

=

array('WebName'=>'PHP网站开发教程网','WebSite'=>'http://www.jb51.net')

$php_json

=

json_encode($json_arr)

echo

$php_json

$php_json

=

json_decode($php_json)

print_r($php_json)

?>

说明:这里通过PHP定义了关联数组,然后通过json_encode转换为JSON格式的数据,通过echo语句可以看到转换后的JSON对象,通过PHP

JSON解析函数json_decode可以将JSON格式的数据解析为PHP的关联数组。如果编码不正确,JSON中文会出现乱码。如果你使用Editplus调试PHP,请注意保存文件时编码将ANSI改为UTF8。

最后我们来看下完整的PHP

JSON交互实例

复制代码

代码如下:

<?php

$json_arr

=

array('WebName'=>'PHP网站开发教程网','WebSite'=>'http://www.jb51.net')

$php_json

=

json_encode($json_arr)

?>

<script

type="text/javascript">

var

php_json

=

<?=$php_json?>

</script>

<script

type="text/javascript">

function

php_json_dis(php_json)

{

alert(php_json.WebName)

alert(php_json.WebSite)

}

php_json_dis(php_json)

</script>

至此,PHP通过json_encode和json_decode函数对JSON格式数据进行转换和解析的实例就介绍完了。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/6768174.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-28
下一篇 2023-03-28

发表评论

登录后才能评论

评论列表(0条)

保存