Я разрабатываю веб-приложение с Symfony 2.6, PHP 5.4 и MySQL 5.6 и Twig. Я также использую YAML а также Bcrypt
В настоящее время я разрабатываю форму входа, я следовал Учебник по Symfony2 но когда я тестирую веб-приложение, я получаю эту ошибку:
Warning: password_verify() expects parameter 2 to be string, resource given
Stack Trace in vendor/symfony/symfony/src/Symfony/Component/Security/Core/Encoder/BCryptPasswordEncoder.php at line 89 -
public function isPasswordValid($encoded, $raw, $salt)
{
return !$this->isPasswordTooLong($raw) && password_verify($raw, $encoded);
}
}
Это связанный код:
security.xml
security:
encoders:
InterempleaBundle\Entity\Usuario:
algorithm: bcrypt
cost: 12
role_hierarchy:
ROLE_ADMIN: ROLE_USER
ROLE_SUPER_ADMIN: [ROLE_USER, ROLE_ADMIN, ROLE_ALLOWED_TO_SWITCH]
providers:
mysql_db_provider:
entity:
class: InterempleaBundle:Usuario
property: email
firewalls:
admin_area:
pattern: ^/IniciaSesion
http_basic: ~
provider: mysql_db_provider
form_login:
login_path: index
check_path: /IniciaSesion/login_check
failure_path: index
access_control:
- { path: ^/IniciaSesion, roles: ROLE_ADMIN }
Entity \ Usuario.php (Пользовательский объект)
class Usuario implements UserInterface, \Serializable {
/**
* @var string
*/
private $email;
/**
* @var string
*/
private $contrasena;
/**
* @var \DateTime
*/
private $fechaultimoacceso;
/**
* @var string
*/
private $imagenperfil;
/**
* @var integer
*/
private $id;
/**
* Set email
*
* @param string $email
* @return Usuario
*/
public function setEmail($email) {
$this->email = $email;
return $this;
}
/**
* Get email
*
* @return string
*/
public function getEmail() {
return $this->email;
}
/**
* Set contrasena
*
* @param string $contrasena
* @return Usuario
*/
public function setContrasena($contrasena) {
$this->contrasena = $contrasena;
return $this;
}
/**
* Get contrasena
*
* @return string
*/
public function getContrasena() {
return $this->contrasena;
}
/**
* Set fechaultimoacceso
*
* @param \DateTime $fechaultimoacceso
* @return Usuario
*/
public function setFechaultimoacceso($fechaultimoacceso) {
$this->fechaultimoacceso = $fechaultimoacceso;
return $this;
}
/**
* Get fechaultimoacceso
*
* @return \DateTime
*/
public function getFechaultimoacceso() {
return $this->fechaultimoacceso;
}
/**
* Set imagenperfil
*
* @param string $imagenperfil
* @return Usuario
*/
public function setImagenperfil($imagenperfil) {
$this->imagenperfil = $imagenperfil;
return $this;
}
/**
* Get imagenperfil
*
* @return string
*/
public function getImagenperfil() {
return $this->imagenperfil;
}
/**
* Get id
*
* @return integer
*/
public function getId() {
return $this->id;
}
public function serialize() {
return serialize(array(
$this->id,
$this->email,
$this->contrasena,
// see section on salt below
// $this->salt,
));
}
public function unserialize($serialized) {
list (
$this->id,
$this->email,
$this->contrasena,
// see section on salt below
// $this->salt
) = unserialize($serialized);
}
public function eraseCredentials() {
}
public function getPassword() {
return $this->contrasena;
}
public function getRoles() {
return array('ROLE_ADMIN');
}
public function getSalt() {
return null;
}
public function getUsername() {
return $this->email;
}
}
LoginAction внутри SecurityController
...
public function loginAction() {
$authenticationUtils = $this->get('security.authentication_utils');
// get the login error if there is one
$error = $authenticationUtils->getLastAuthenticationError();
// last username entered by the user
$lastUsername = $authenticationUtils->getLastUsername();
$repositorioUsuario = $this->getDoctrine()->getRepository('InterempleaBundle:Usuario');
$usuario = $repositorioUsuario->loadUserByUsername($lastUsername);
return $this->render(
'InterempleaBundle:Usuario:panel_principal.html.twig', array(
// last username entered by the user
'last_username' => $usuario->id,
'error' => $error,
)
);
}
...
Я сомневаюсь в атрибуте salt внутри сущности, но в учебнике говорится, что он должен быть нулевым.
Что это может происходить? Я пропустил какой-то шаг?
Не стесняйтесь спрашивать любой другой код или объяснение.
Заранее спасибо!
Следуя предложению @Martin Rios, я проверил содержание $encoded
переменная, и я понял, что в Учебник по Symfony2 поле пароля в базе данных было VARCHAR (64) и у меня был двоичный (64) вместо. Поэтому я изменил тип данных на поле пароля, заново сгенерировал сущности с помощью команд Doctrine, очистил кеш, и это сработало!
Других решений пока нет …