无法从苗条的服务器接收响应

时间:2017-01-13 08:33:20

标签: php ajax slim

我们正在使用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);
      }
    })
  })
})

代码总是跳过“成功”部分并直接跳转到“错误”。 那么我们的代码有什么问题呢?提前谢谢。

1 个答案:

答案 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解码。