ThinkPHP中使用ajaxReturn进行ajax交互

时间:2022-04-25 16:06:15
以管理员登录为例来介绍下$this->ajaxReturn与模板页进行ajax交互使用方法
首先看PHP控制器的处理,在application/Admin/Controller/LoginController.class.php控制器里加入登录验证方法
//ajax检验管理员登录是否正确
public function check()
{
  $user = M('User');
  if(!IS_AJAX){
    $this->ajaxReturn(array(
      'info' => '非法的请求方式'
    ));   }
  $user_name = I('user_name', '');
  $user_password = I('user_password', '');   $user_password = md5($user_password);   $filter = array(
    'user_name' => $user_name,
    'user_password' => $user_password
  );   $user_info = $user->where($filter)->find();   if (1 == $user_info['type']) {
    $this->ajaxReturn(array(
      'info' => '你无权登录后台'
    ));
  }   if($user_info){
    // 更新登录ip
    $info['ip'] = get_client_ip();
    //更新登录时间
    $info['update_time'] = date('Y-m-d H:i:s', time());     $user->where(array('id' => $user_info['id']))->save($info);     session('user_id',$user_info['id']);     $data = array(
      'info' => 'ok',
      'callback' => U('user/index/index')
    );
  }else{
    $data = array(
      'info' => '登录失败,请检查登录名和密码是否正确'
    );   }   $this->ajaxReturn($data);
}

  

 登录模板页
$('.submit').click(function(event){
  //阻止表单默认提交事件
  event.preventDefault();
  var userName=$("#user_name").val();
  var userPassword=$("#user_password").val();
  if(userPassword==""||userName==""){
    alert('登录名与密码不能为空 ');
    $("#user_name").focus();
    return false;
  }else{
    var url = "{U('Admin/Login/check')}";
    $.post(url, { user_name:userName, user_password:userPassword}, function(msg){
      if(msg.info == 'ok') {
        //alert('登录成功,正在转向后台主页!');
        window.location.href = msg.callback;
      } else {
        alert(msg.info);
      }
    }, 'json').error(function(){
      alert("网络连接错误,请稍后再试");
    });   }
})