[英]How do I bcrypt password when inserting into MySQL?
我正在尝试使用Laravel 4创建用户注册表单,但是在插入数据库之前无法对密码进行加密。 我的示例代码如下。
app / model / Register.php中的代码
class Register extends Eloquent {
protected $guarded = array();
protected $table = 'login'; // table name
public $timestamps = 'true' ; // to disable default timestamp fields
// model function to store form data to database
public static function saveFormData($data)
{
DB::table('login')->insert($data);
}
}
RegisterController.php上的代码
public function store()
{
$data = Input::except(array('_token')) ;
$rule = array(
'firstName'=>'required|alpha|min:2',
'lastName'=>'required|alpha|min:2',
'email'=>'required|email|unique:intern_login',
'password'=>'required|alpha_num|min:8'
) ;
$validator = Validator::make($data,$rule);
if ($validator->fails())
{
return Redirect::to('register')
->withErrors($validator->messages());
}
else
{
Register::saveFormData(Input::except(array('_token')));
return Redirect::to('register')
->withMessage('Data inserted');
}
}
在routes.php中的代码
Route::post('register_action', function()
{
$obj = new RegisterController() ;
return $obj->store();
});
提前致谢。
如文档中所述,您必须使用Hash::make
函数。
$password = Hash::make('secret');
也就是说,您的代码摘录表明您不了解Laravel的工作方式。 您阅读过文档或任何教程吗?
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.