2011-05-24 57 views
0

:)此问题适用于任何熟悉Tankauth插件的人。Codeigniter帮助用户注册脚本

我编辑了tankauth,以便在没有电子邮件验证的情况下填充用户配置文件。

在注册表单中,我添加并验证了两个名为“first_name”和“last_name”的字段,我想在提交表单时将其添加到user_profiles表中。

下面是tankauth函数,如果用户被激活,它将用户ID添加到user_profiles表。我评论说如果($激活)。问题是我不知道如何将我的新字段first_name和last_name插入到数据库中。我不断尝试任何错误。

function create_user($data, $activated = TRUE) 
    { 
     $data['created'] = date('Y-m-d H:i:s'); 
     $data['activated'] = $activated ? 1 : 0; 

     if ($this->db->insert($this->table_name, $data)) { 
      $user_id = $this->db->insert_id(); 
      //if ($activated) 
      $this->create_profile($user_id); 
      return array(
         'user_id' => $user_id, 
         'first_name' => $first_name, //added by me 
               'first_name' => $first_name, //added by me 
         ); 
     } 
     return NULL; 
    } 

以上与

private function create_profile($user_id) 
    { 
     $this->db->set('user_id', $user_id); 
     $this->db->set('first_name', $first_name); //added by me 
     return $this->db->insert($this->profile_table_name); 
    } 

连接是否有人可以分享一些指导?

回答

1

尝试删除privateprivate function create_profile

你也可能要改变你的create_profile功能是:

function create_profile($user_id) { 
    $data = array(
     'user_id' => $user_id, 
     'first_name' => $first_name // Hopefully this is being set correctly. 
    ); 

    return $this->db->insert($this->profile_table_name, $data); 
} 

如果没有这些工作。尝试使用echo $this->db->last_query();

希望有所帮助。

+0

谢谢!它似乎也与私人工作。我也尝试在create_user函数中添加一个数组并将其传递给create_profile。这也是有效的 – CyberJunkie 2011-05-24 02:54:30