Ajax中的JSON格式与php传输过程全面解析
发布:smiling 来源: PHP粉丝网 添加日期:2021-08-19 17:18:43 浏览: 评论:0
这篇文章主要介绍了Ajax中的JSON格式与php传输过程及注意事项,文中给大家提到了JSON与php传输数据的代码,需要的朋友参考下吧。
在Ajax中的JSON格式与php传输过程中有哪些要注意的小地方呢?
先来看一下简单通用的JSON与php传输数据的代码
HTML文件:
- <input type="button" value="Ajax" id="btn">
- <script>
- var btn = document.getElementById("btn");
- btn.onclick = function(){
- var xhr = getXhr();
- xhr.open("post","测试.php");
- xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
- var user = '{"name":"zhangwuji","pwd":"123456"}';
- xhr.send("user="+user);
- xhr.onreadystatechange = function(){
- if(xhr.readyState==4&&xhr.status==200){
- var data = xhr.responseText;
- var json = eval("("+data+")");
- console.log(json);
- }
- }
- }
- function getXhr(){
- var xhr = null;
- if(window.XMLHttpRequest){
- xhr = new XMLHttpRequest();
- }else{
- xhr = new ActiveXObject("Microsoft.XMLHttp");
- }
- return xhr;
- }
- </script>
在整个过程中先要获得AJAX对象,然后用POST请求方式与PHP文件连接,这时候用的是POST方法请求数据,所以这时候还要加上一个请求文件头
xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");这是固定写法直接记下来就可以了。<br><br>上面的是测试代码,创建一个json格式的字符串并用SEND方法传入PHP:
var user = '{"name":"zhangwuji","pwd":"123456"}';
xhr.send("user="+user);<br><br>这时候要注意了,在构建JSON字符串传输的时候user里面的字符串外面要用单引,里面用双引,不然php那边是不认为你这是JSON 不能正确的进行解析,<br><br><br>这时候看看PHP文件里的代码:
- <?php
- // 接收客户端发送的请求数据
- $user = $_POST['user'];
- // 就是一个JSON格式的string字符串
- $json_user = json_decode($user,true);//对json格式的字符串进行解码,转换成PHP变量格式
- // 2. 使用json_encode()函数
- echo json_encode($json_user);//对php变量格式进行编码,转换成JSON格式
- ?>
json_decode 和json_encode大家从字面的意思都应该可以看出来一点,decode在这这里的作用就是对json格式的字符串进行解码,转换成PHP变量格式而encode就是对php变量格式进行编码,转换成JSON格式在传输回去;
这时候PHP 文件的工作已经结束了,让我们在回到HTML文件看接受数据的onreadystatechange这一块的代码:
var data = xhr.responseText; 虽然PHP文件传输回来的是一个JSON格式,但是我们这里接受用的是respenseText所以接收到的只是一个文本格式的字符串<br>这时候我们还要用eval();函数将其转换成JSON格式
* 使用eval()函数进行转换
使用"()"将其包裹,eval()函数强制将其转换为JSON格式(javascript代码)
不使用"()"将其包裹,eval()函数将其识别为一个空的代码块
Tags: Ajax JSON
相关文章
- ·php使用ajax示例(2013-12-09)
- ·php ajax注册验证用户名是否存在代码(2013-12-11)
- ·Ajax用户注册验证(2013-12-16)
- ·php ajax交互汉字乱码的问题解决方法(2013-12-19)
- ·ajax php用户无刷新登录实例(2013-12-23)
- ·php ajax实现验证用户名是否存在(2014-07-31)
- ·php ajax实现无刷新检测用户名是否可用(2014-08-01)
- ·php jquery.ajax无刷新登录简单实例代码(2014-08-04)
- ·php ajax 无刷新翻页实现代码(2014-08-06)
- ·用户注册检测用户名是否存在ajax+php代码(2014-08-15)
- ·PHP和AJAX的RSS阅读器(2014-08-20)
- ·PHP验证码之Ajax验证实现方法(2014-08-22)
- ·ajax+php验证用户名重复代码实例(2014-09-11)
- ·php+ajax用户注册验证用户是否在存(2014-09-11)
- ·php ajax返回 json数据实例(2014-09-20)
- ·php ajax数据提交post与post常见方法(2014-09-21)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)