gpt4 book ai didi

php - 在 codeigniter 中使用回调表单验证来比较日期

转载 作者:行者123 更新时间:2023-11-29 16:02:42 26 4
gpt4 key购买 nike

我进行了回调,并有一个 if 条件,将输入字段付款日期与数据库中的最后付款日期和今天的日期进行比较。它不应等于或早于上次付款日期,并且应等于或小于今天的日期。

当我选择的日期大于今天的日期时,它会返回 false,但即使我选择的日期等于或早于上次付款日期,它也会返回 true。

我尝试比较 Controller 内的输入字段和最后付款日期,而不是在回调函数中,它工作得很好。当我在comparePaymentDate中回显$projectID时,它显示输入日期字段中的日期而不是项目ID。但是当我在 validatePaymentAdd 函数中回显 $projectID 时,它显示了正确的项目 ID。

在我的 Controller 中

$validate = $this->my_form_validation_lib->validatePaymentAdd($projectID);
$this->form_validation->set_rules($validate);

和回调

public function comparePaymentDate($projectID){
$latestPayment = $this->payment_model->getLatestPayment($projectID);
$fieldPaymentDate = strtotime($this->input->post('form_payment_date'));

if($fieldPaymentDate <= strtotime($latestPayment['payment_date']) || $fieldPaymentDate > strtotime(date('Y-m-d'))) {
$this->form_validation->set_message('comparePaymentDate', 'Payment Date should be later date than the latest payment and earlier or equal to the date today.');
return FALSE;
} else{
return TRUE;
}
}

我的自定义库中返回规则的函数

function validatePaymentAdd($projectID){
$rules = array(
array(
'field' => 'form_milestone',
'label' => 'Milestone',
'rules' => 'trim|required|alpha_numeric_spaces'
),
array(
'field' => 'form_payment_date',
'label' => 'Payment Date',
'rules' => 'required|callback_comparePaymentDate['.$projectID.']'
),
array(
'field' => 'form_payment_made',
'label' => 'Amount Paid',
'rules' => array(
'trim', 'required', 'greater_than_equal_to[0]',
'callback_payment'
)
),
array(
'field' => 'form_payment_remarks',
'label' => 'Payment Remarks',
'rules' => 'trim|required'
),
array(
'field' => 'remarks_subject',
'label' => 'Remarks Subject',
'rules' => 'trim|required'
),
array(
'field' => 'remarks_field',
'label' => 'Remarks',
'rules' => 'trim|required'
)
);
return $rules;
}

从数据库获取最后付款日期的函数

public function getLatestPayment($projectID){
$this->db->select('payment_date');
$this->db->from('payment');
$this->db->where('project_id', $projectID);
$this->db->order_by('payment_id', 'Desc');
$this->db->limit(1);
$payment = $this->db->get();
return $payment->row_array();
}

例如:输入日期:2019 年 5 月 2 日最后付款日期:2019 年 5 月 5 日

它应该返回 false 并返回错误

最佳答案

解决了问题。显然回调函数中的第一个参数是输入字段,第二个参数是要传递的数据。

所以现在的回调是

public function uniqueProjectName($input_field, $clientID){
$projectName = $this->client_profile_model->compareProjectName($clientID);
if($projectName > 0) {
$this->form_validation->set_message('uniqueProjectName', 'Project Name should be unique.');
return FALSE;
} else{
return TRUE;
}
}

关于php - 在 codeigniter 中使用回调表单验证来比较日期,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56042162/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com