我们正在使用php-framework“slim”来建立一个电子商店。现在我们遇到一个问题,我们可以向服务器发送请求并修改数据库(我们检查了表并且确实已经更改),而Web端无法从数据库获得响应(iOS和Android端都可以获得它)。以下是发送请求,更新数据库并获取响应的代码部分:
$app->post('/tblUser', function($request, $response, $args) {
get_tblUser_id($request->getParsedBody());
});
function get_tblUser_id($data)
{
$db = connect_db();
$sql = "update tblphoneverify set dtCreate = NOW() where strPhone = $data[phone]";
$db->query($sql);
$updateId = $db->affected_rows;
$db = null;
$msg = array(
'stat' => '',
'msg' => ''
);
$msg['stat'] = '1';
$msg['msg'] = 'registration success';
return json_encode($msg);
}
然后这个ajax段触发click事件来执行post并接收结果的状态:
$(function(){
$("#getcheck").click(function(){
$.ajax({
type:"post",
url:"http://192.168.1.108/blue/public/tblUser",
data: {"phone":"13331111111"},
dataType:"json",
//async:false,
contentType: "application/x-www-form-urlencoded",
success:function(data){
alert(1);
},
error:function(XMLHttpRequest, textStatus, errorThrown){
alert(XMLHttpRequest.readyState);
alert(XMLHttpRequest.status);
alert(XMLHttpRequest.statusText);
alert(XMLHttpRequest.responseText);
alert(textStatus);
alert(errorThrown);
}
})
})
})
代码总是跳过“成功”部分并直接跳转到“错误”。 那么我们的代码有什么问题呢?提前谢谢。
答案 0 :(得分:0)
您应该从可调用的路由发送响应。不要json_encode
自己,而是让Slim去做。
首先,从get_tblUser_id
返回一个数组:
function get_tblUser_id($data)
{
$db = connect_db();
$sql = "update tblphoneverify set dtCreate = NOW() where strPhone = $data[phone]";
$db->query($sql);
$updateId = $db->affected_rows;
$db = null;
$msg = array(
'stat' => '',
'msg' => ''
);
$msg['stat'] = '1';
$msg['msg'] = 'registration success';
return $msg;
}
请注意,此处有一个SQL注入漏洞。将SQL更改为以下内容:
$sql = "update tblphoneverify set dtCreate = NOW() where strPhone = ?";
$db->query($sql, [$data[phone]]);
接下来,您需要从路由callable发送一个JSON响应。 Slim有一种方法可以做到这一点:
$app->post('/tblUser', function($request, $response, $args) {
$msg = get_tblUser_id($request->getParsedBody());
return $response->withJson($msg);
});
Slim现在将使用正确的内容类型标头集发回msg
数组,这有助于您的JavaScript解码。