[英]jquery ajax post doesn't work
我阅读了许多有关此问题的文章,但无法解决问题。 似乎ajax()可以正常工作,但是.php文件无法更新SQL数据库,并且没有向ajax()函数返回任何结果。
这是我的代码:
var datastring=JSON.stringify(utnew) $.ajax({ type: "POST", url: "myulr-php", data: datastring, dataType: "json", success: function(resto){ if (resto=="success"){ $("#pop-confermadatiuser").html("OK"); }else{ $("#pop-confermadatiuser").html("KO"); }; } });
PHP代码的工作,我已经尝试过。 这是代码:
header("Access-Control-Allow-Origin: *"); $con = mysqli_connect("sql","xxx","xxx","xxx") or die ("could not connect database"); $ck=1 ; if(isset($_POST['id'])) { $id=$_POST['id']; $nome=$_POST['nome']; $cognome=$_POST['cognome']; $matricola=$_POST['matricola']; $mail=$_POST['mail']; $password=$_POST['password']; $ck=2 $qry="UPDATE user SET nome='".$nome."', cognome='".$cognome."', mail='".$mail."', password='".$password."' where id=".$id." and matricola=".$matricola; $q=mysqli_query($con,$qry); if($q) { echo "success"; } else { echo "error"; }; mysqli_close($con); }; if(ck==1){ echo "error2"; };
jQuery代码将POST数据作为JSON字符串发送,但是您的PHP代码正在寻找标准的键值对。
您可以将Ajax调用更改为以键值格式发送。 我看不到utnew
在您的代码utnew
是什么,通常是Javascript对象或使用$.serialize()
序列化HTML表单的结果:
$.post("myurl.php", utnew, "json")
.always(function(response) { console.log(response); }
或者,您可以更改PHP端,以便在POST有效负载中使用JSON编码的字符串,而不是编码的键值对:
<?php
...
$data = json_decode(file_get_contents('php://input'));
if (isset($data['id'])) { ... }
无论选择哪种方法,您遇到的问题都是Ajax调用发送了一个JSON编码的字符串作为POST负载,但是PHP期望$_POST
的键值对。
jQuery $.ajax
的"json"
数据类型参数或快捷方式方法$.post
告诉jQuery期望返回值的格式,因此您的PHP代码应返回JSON编码的字符串。 您的PHP代码发送回一个纯字符串,因此您应该告诉jQuery期望:
$.post(url, data, "text")
或让PHP发回适当的JSON编码对象:
echo json_encode(["result" => "success"]);
如果您有PHP错误登录(应该登录)到文件,则可以使用error_log
调试API端点,即error_log(print_r($_POST,1));
会给你一些线索。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.