2013-10-18 97 views
0

我正在探索codeigniter很长一段时间,我在探索它时遇到的大部分问题已经通过Google搜索解决了,但现在我面临的问题有点奇怪。所以情况就是这样。如果验证后没有错误,我有一个控制器将验证表单并将所有输入从表单传递到模型。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();之后的东西,它的工作原理。我做了一些测试,电子邮件功能工作正常。但是当我以这种方式呼叫$this->Adduserinfointoactivationtable->addUserInfo($user_infos);后,它不发送电子邮件。我也注意到无论我在$this->Adduserinfointoactivationtable->addUserInfo($user_infos);之后做什么,例如加载视图或回显某些内容,它都不起作用。

有人能告诉我这个吗?

+0

你为什么要这么做$查询 - > result_array(); ?? –

+0

是的,太粗心了,因为复制代码并粘贴它没有双重检查。由于插入了数据,下次应该多关注模型,所以我没有太在意模型。再次感谢评论并指出。 :) – Chivaa

回答

1

我认为你的问题可能是,根据CodeIgniter documentation$this->db->query()返回一个布尔值,如果执行“插入”类型的查询。

这发生在你的情况。因此,您可能会通过执行$query->result_array()来创建致命错误。

举一个简单的修复,你也许可以尝试以下方法:

if (is_object($query)) { 
    return $query->result_array(); 
} else { 
    return $query; 
} 
+0

嗨garbetjie,谢谢一堆。是的,它现在有效。这可能是如此愚蠢,因为我插入的数据,而不是选择数据...我会接受这个答案。 :) – Chivaa

0

您不在其他部分加载任何视图,对吗?做一个重定向到相同的功能或成功功能页面。

+0

嗨Nil'z。正如我所说我试图做简单的事情,只是回声后,并没有工作。 – Chivaa