Home > Backend Development > PHP Tutorial > ajax post数据提交 PHP后台接收不到数据

ajax post数据提交 PHP后台接收不到数据

WBOY
Release: 2016-06-23 13:37:02
Original
2006 people have browsed it

JS的脚本提交

$.ajax({			url:"/music/json.php",			type:"POST",			data:{"id":id},			dataType:"json",			success: function(e){
Copy after login




PHP后台:
//这里不知道怎么接收数据  echo $_POST["id"]; //不行  echo json_decode($_POST['data']);//不行//下面就是数据库查询$query="select * from gequ where id='$_POST[id]'";//执行查询语句不正确,尝试各种方法如上面获取ID的数据未果来求助$result=mysql_query( $query );
Copy after login



传值如下:
id:xxxx
看了论坛上有关帖子,始终不能解决问题,在不改变JS的脚本的情况下,如何在后台接收传值


回复讨论(解决方案)

正常提交请不要加dataType:"json",
否则你需要print_r(json_decode($_POST['id']))这个是数组 不能echo

刚写了ajax post删除 给你发出来吧

 function deleteall(){                var checkboxs = document.getElementsByName("selects");                var ids = new Array();                 for(var i = 0 ; i<checkboxs.length ; i++){                    if(checkboxs[i].checked == true){                        ids[i] = checkboxs[i].value;                    }                }                if(ids.length<1){                    return false;                }                var newids = ids.join(",");                if(confirm("确认删除?")){                    $.ajax({                     type: "POST",                     url: "<?php echo url('autoReply','deleteall')?>",                     data:"id="+newids,                     success: function(e){                        if(e == 1 ){                           for(var i = 0 ; i<checkboxs.length ; i++){                            if(checkboxs[i].checked == true){                                checkboxs[i].checked = false;                            }                            }                           location.reload();                       }else{                          alert("删除失败");                      }                     }                    })                }            }
Copy after login

另外

$query="select * from gequ where id='$_POST[id]'";
Copy after login

如果你post过来的id是int类型的话 完全没必要加单引号

data:{"id":id},

在JS里面alert一下这个id,看是否有值

<html>    <head>        <title>title</title>        <script src="http://libs.baidu.com/jquery/1.9.0/jquery.min.js"></script>        <script>         $(function(){            $("#btn").click(function(){                alert('ok!');                var id = 3;                $.ajax({                    url:"2.php",                    method:"POST",                    dataType:"json",                    data:{id:id},                    success:function(data){                       alert(data.id);                    }                                                        });                            });        });        </script>    </head>    <body>        <input type="button" id="btn" value="button">    </body></html>
Copy after login
Copy after login


2.php文件
<?php$dd['id'] = $_POST['id'];$dd['value'] = 'fff';echo json_encode($dd);?>
Copy after login
Copy after login


另外楼上有位说 dataType不用写,下面是引用官方文档的解释。

dataType (default: Intelligent Guess (xml, json, script, or html))
Type: String
The type of data that you're expecting back from the server. I

正常提交请不要加dataType:"json",
否则你需要print_r(json_decode($_POST['id']))这个是数组 不能echo



一下就懂了,缺少json_decode啊,赞个,分就给你了
顺便再问个跟这个没多大关系的问题

$.ajax({
url:"/music/",
type:"POST",
data:{"id":id},
dataType:"json",
success: function(e){

如果URL是这样传递的,这是什么技术呢

我擦 楼主你看看5楼,

你看看 官方给的 介绍:http://api.jquery.com/jquery.ajax/

dataType (default: Intelligent Guess (xml, json, script, or html))
Type: String
The type of data that you're expecting back from the server. If none is specified, jQuery will try to infer it based on the MIME type of the response (an XML MIME type will yield XML, in 1.4 JSON will yield a JavaScript object, in 1.4 script will execute the script, and anything else will be returned as a string). The available types (and the result passed as the first argument to your success callback) are:

<html>    <head>        <title>title</title>        <script src="http://libs.baidu.com/jquery/1.9.0/jquery.min.js"></script>        <script>         $(function(){            $("#btn").click(function(){                alert('ok!');                var id = 3;                $.ajax({                    url:"2.php",                    method:"POST",                    dataType:"json",                    data:{id:id},                    success:function(data){                       alert(data.id);                    }                                                        });                            });        });        </script>    </head>    <body>        <input type="button" id="btn" value="button">    </body></html>
Copy after login
Copy after login


2.php文件
<?php$dd['id'] = $_POST['id'];$dd['value'] = 'fff';echo json_encode($dd);?>
Copy after login
Copy after login


另外楼上有位说 dataType不用写,下面是引用官方文档的解释。

dataType (default: Intelligent Guess (xml, json, script, or html))
Type: String
The type of data that you're expecting back from the server. I



我擦 楼主你看看5楼,

你看看 官方给的 介绍:http://api.jquery.com/jquery.ajax/

dataType (default: Intelligent Guess (xml, json, script, or html))
Type: String
The type of data that you're expecting back from the server. If none is specified, jQuery will try to infer it based on the MIME type of the response (an XML MIME type will yield XML, in 1.4 JSON will yield a JavaScript object, in 1.4 script will execute the script, and anything else will be returned as a string). The available types (and the result passed as the first argument to your success callback) are:




你理解错我意思了,dataType是要写的,我问题主要是json_decode而已,你是对的

我说的datatype不用写是如果不牵扯到跨域传值或者js的数组 /对象 的话 字符串完全可解决 所以就没必要加datatype  比如你要已json格式传递

另外 url:"/music/",  很简单就能理解  就是当前目录下的/music/
比如你访问www.xxx.com/music/  那么如果设置了默认文件了 会直接访问默认文件的 
比如默认文件时index.php那么实际就是www.xxx.com/music/index.php
另外json_decode()有2个参数 第一个是json 第二个如果不想要对象的话请写true

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template