如何获取$list_data_l?,当我点击登录它只是出现错误禁止.我通常不会在php上使用try catch,所以我调试变量的方式是使用var_dump,但在这种情况下,我不能使用变量来获得调试变量。是否有调试变量$list_data_l的替代解决方案?我已经使用了print_r,echo和var_dump,它们都不起作用。请帮
if ($this->input->is_ajax_request()) {
try {
$this->form_validation->set_rules('userid', 'ID', 'required|xss_clean');
$this->form_validation->set_rules('pass', 'Password', 'required|xss_clean');
if ($this->form_validation->run() == FALSE)
throw new Exception(validation_errors("", ""), 0);
date_default_timezone_set("Asia/Jakarta");
$current_date_time = date("Y-m-d H:i:s");
$this->two_db = $this->load->database('database_two', TRUE);
$userid = $this->input->post("userid");
$pass = $this->input->post("pass");
$pass1 = md5($pass . "monda");
$sql1 = "SELECT A.id, A.userid,A.`name`,A.`active_flag`,A.`group`
FROM login_session A
WHERE A.`userid`=? AND A.`password`=? ";
$bind1 = array($userid, md5($pass . "monda"));
$list_data_l = $this->two_db->query($sql1, $bind1);
var_dump($list_data_l);
die;
if (!$list_data_l)
throw new Exception("SQL 2 Error!");
if ($list_data_l->num_rows() == 0)
throw new Exception("Id Login atau Password salah!");
$sql = "SELECT A.id, A.userid,A.`name`,A.`active_flag`,A.`groupid`,B.`name` groupname,A.unit_code
FROM tbl_user A
INNER JOIN `tbl_user_group` B ON A.`groupid`=B.`id`
WHERE A.`userid`=? ";
$bind = array($userid);
$list_data = $this->db->query($sql, $bind);
if (!$list_data)
throw new Exception("SQL Error!");
if ($list_data->num_rows() == 0)
throw new Exception("Wrong Combination!");
if ($list_data->row()->active_flag != 'Y')
throw new Exception("Your account is blocked!");
$this->session->set_userdata('peppd', $list_data->row());
//update last access
$this->db->trans_begin();
$this->m_ref->setTableName("tbl_user");
$data_baru = array(
"last_access" => $current_date_time,
);
$cond = array(
"id" => $list_data->row()->id,
);
$status_save = $this->m_ref->update($cond, $data_baru);
if (!$status_save) {
throw new Exception($this->db->error("code") . " : Failed save data", 0);
}
$this->db->trans_commit();
$output = array(
"status" => 1,
"msg" => "You logged in",
"csrf_hash" => $this->security->get_csrf_hash(),
);
exit(json_encode($output));
} catch (Exception $e) {
$this->db->trans_rollback();
$this->load->helper('captcha');
$original_string = array_merge(range(1, 9), range('A', 'Z'));
$original_string = implode("", $original_string);
$captcha = substr(str_shuffle($original_string), 0, 5);
$vals = array(
'word' => $captcha,
'img_path' => './captcha/',
'font_path' => './fonts/KeepCalm-Medium.ttf',
'img_url' => base_url("captcha"),
'img_width' => 200,
'img_height' => 30,
'expiration' => 7200,
'word_length' => 5,
'font_size' => 15,
'pool' => '123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ',
// White background and border, black text and red grid
'colors' => array(
'background' => array(255, 255, 255),
'border' => array(255, 255, 255),
'text' => array(0, 0, 0),
'grid' => array(255, 73, 142)
)
);
$cap = create_captcha($vals);
// print_r($cap);exit();
$this->session->set_userdata("captchaword", $cap["word"]);
$output = array(
'status' => 0,
"msg" => $e->getMessage(),
"captcha_img" => $cap["image"],
"csrf_hash" => $this->security->get_csrf_hash(),
);
exit(json_encode($output));
}
} else {
echo "denied";
}
1条答案
按热度按时间wn9m85ua1#
看起来你正在测试一个 AJAX 请求(也称为XHR),所以你应该在浏览器的开发工具网络选项卡中查找输出,过滤为“XHR”:
通过回显
try
之后的行上的内容来检查是否到达了try
块:在代码中向下移动
echo
和exit
,直到发现没有到达。这是您找到有问题的线路的方法。如果抛出异常或错误,则try
块的其余部分将不会执行。这也许可以解释为什么看不到var_dump
的输出。将
catch
块更改为捕获Throwable
,以便它可以捕获异常和错误。通过回显
catch
之后的行上的内容来检查是否到达了catch
块。