我正在探索Codeigniter很长一段时间,我在探索它时遇到的大部分问题已经通过谷歌搜索解决了,但我现在面临的问题有点奇怪。所以情况是这样的。我有一个控制器,如果验证后没有错误,它将验证表单并使用数组将所有输入从表单传递到模型。
我在同一个控制器中还有另一个功能,它将在调用时发送电子邮件。因此,我想做的是验证表单,使用数组发送所有输入以建模并将其插入数据库,然后将电子邮件发送到用户的电子邮件地址。
以下是来自注册控制器的部分代码:
if($this->form_validation->run() == FALSE){
//load custom config
$this->config->load('site_config', TRUE);
$this->load->library('session');
$this->load->helper('form');
//retrieve data
$data['site_title'] = $this->config->item('site_title', 'site_config');
$data['site_login'] = $this->config->item('site_login', 'site_config');
$data['site_url'] = $this->config->item('site_url', 'site_config');
$data['img_folder_path'] = $this->config->item('img_folder_path', 'site_config');
$this->load->view('view_header', $data);
$this->load->view('view_signup',$data);
$this->load->view('view_footer');
}else{
$this->load->model('Adduserinfointoactivationtable');
$user_infos = array('first_name' => $this->input->post('first_name'),
'last_name' => $this->input->post('last_name'),
'email' => $this->input->post('email'),
'tel' => $this->input->post('tel'),
'fax' => $this->input->post('fax'),
'add_1' => $this->input->post('add_1'),
'add_2' => $this->input->post('add_2'),
'city' => $this->input->post('city'),
'post_code' => $this->input->post('post_code'),
'state' => $this->input->post('state'),
'password' => sha1($this->input->post('pass_2')),
'activation_code' => sha1(sha1($this->input->post('email').$this->input->post('pass_2'))),
);
$this->Adduserinfointoactivationtable->addUserInfo($user_infos);
$this->send_mail();
}
这是模型:
public function addUserInfo ($user_infos){
$sql = "INSERT INTO tbl_user_Account (email_add, activation_code, fname, lname, tel, fax, add1, add2, city, post_code, state, password) VALUES (?,?,?,?,?,?,?,?,?,?,?,?);";
$query = $this->db->query($sql, array($user_infos['email'], $user_infos['activation_code'], $user_infos['first_name'], $user_infos['last_name'], $user_infos['tel'], $user_infos['fax'], $user_infos['add_1'], $user_infos['add_2'], $user_infos['city'], $user_infos['post_code'], $user_infos['state'], $user_infos['password']));
$query->result_array();
}
当我将$this->send_mail();
放在 ELSE 之后时,它可以工作。我做了一些测试,电子邮件功能工作正常。但是当我这样称呼它时,它是在$this->Adduserinfointoactivationtable->addUserInfo($user_infos);
之后,它不会发送电子邮件。我还注意到,无论我在$this->Adduserinfointoactivationtable->addUserInfo($user_infos);
后做什么,例如加载视图或回显某些内容,它都不起作用。
有人可以建议我吗?
我认为
您的问题可能是以下事实:根据 CodeIgniter 文档,如果执行"插入"类型查询,$this->db->query()
会返回布尔值。
这种情况正在您的案例中发生。因此,您可能会通过执行 $query->result_array()
创建致命错误。
作为简单的解决方法,您可以尝试以下方法:
if (is_object($query)) {
return $query->result_array();
} else {
return $query;
}
您没有在 else 部分中加载任何视图,是吗?重定向到同一功能或成功功能页面。