【发布时间】:2011-07-12 11:42:26
【问题描述】:
我想知道将信息从控制器传递到模型时被认为是最佳实践。更具体地说,我正在一个用户类中创建一个用户注册模型,该模型要求提供某些信息,例如电子邮件、姓名和密码。
我想知道将参数放在模型函数中并以这种方式传递它们是否更好,或者只调用函数并使用 $_POST 变量进行查询是否更好。
这是我所指的两个例子。
方法一
function register(){
$first_name = $this->input->post('first_name');
$last_name = $this->input->post('last_name');
$email = $this->input->post('email');
$password = $this->input->post('password_1');
$this->user_model->register_user($email, $password, $first_name, $last_name));}
function register_user($email, $password, $first_name, $last_name){
$sql = "INSERT INTO users (user_id, email, passwd, first_name, last_name, registration_date, confirmed, confirmation_code, banned)VALUES (NULL, ?, ?, ?, ?, '".date('Y-m-d')."', 'no', '1fg455675', 'no')";
$register = $this->db->query($sql, array($email, $password, $first_name, $last_name));
return $register;
}
方法二
function register(){
$this->user_model->register_user());
}
function register_user(){
$first_name = $this->input->post('first_name');
$last_name = $this->input->post('last_name');
$email = $this->input->post('email');
$password = $this->input->post('password_1');
$sql = "INSERT INTO users (user_id, email, passwd, first_name, last_name, registration_date, confirmed, confirmation_code, banned)VALUES (NULL, ?, ?, ?, ?, '".date('Y-m-d')."', 'no', '1fg455675', 'no')";
$register = $this->db->query($sql, array($email, $password, $first_name, $last_name));
return $register;
}
我已经删除了很多验证代码以及不简化问题的内容,希望您能理解。
【问题讨论】: