Я пытаюсь реализовать функцию забытого пароля в существующем приложении Symphony.Таким образом, у меня есть запрос на восстановление пароля.Пользователь вводит свою электронную почту, и электронное письмо отправляется с токеном.Обратный URL выглядит примерно так:
/ intranet / change-password / f74eab6dca8b5ed6fd46e7893221254b655f94799589e0b83c
Обычно должен отображаться формат, но когда я вижу этот URL, я получаю это сообщение:
* 10061007 * Class App \ Controller \ ResettingController не существует в / public_html / intranet / src / AppBundle / Controller / (который импортируется из "/public_html/intranet/app/config/routing.yml").Убедитесь, что аннотации установлены и включены.
Я не понимаю ... У меня установлен контроллер в нужном месте, и аннотации должны учитывать маршрут.
Мой файл маршрутизации:
app:
resource: "@AppBundle/Controller/"
type: annotation
coop_tilleuls_forgot_password.reset:
path: '/api/forgot-password'
defaults: { _controller: coop_tilleuls_forgot_password.controller.forgot_password:resetPasswordAction}
methods: [POST]
coop_tilleuls_forgot_password.update:
path: '/api/reset-password/{tokenValue}'
defaults: { _controller: coop_tilleuls_forgot_password.controller.forgot_password:updatePasswordAction}
что касается моего класса перерасчета, он находится в / public_html / intranet / src / AppBundle / Controller
И выглядит так:
<?php
// src/Controller/ResettingController.php
namespace App\Controller;
use Symfony\Component\Routing\Annotation\Route;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\Validator\Constraints\Email;
use Symfony\Component\Validator\Constraints\NotBlank;
use Symfony\Component\Form\Extension\Core\Type\EmailType;
use Symfony\Component\Security\Csrf\TokenGenerator\TokenGeneratorInterface;
use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException;
use Symfony\Component\Validator\Validator\ValidatorInterface;
use Symfony\Component\Translation\TranslatorInterface;
use Symfony\Component\Security\Core\Encoder\UserPasswordEncoderInterface;
use Symfony\Component\Form\FormErrorIterator;
use App\Entity\User;
use App\Services\Mailer;
use App\Form\ResettingType;
/**
* @Route("/password-change")
*/
class ResettingController extends Controller
{
/**
* @Route("/{id}/{token}", name="resetting")
*/
public function resetting(User $user, $token, Request $request, UserPasswordEncoderInterface $passwordEncoder)
{
// interdit l'accès à la page si:
// le token associé au membre est null
// le token enregistré en base et le token présent dans l'url ne sont pas égaux
// le token date de plus de 10 minutes
if ($user->getToken() === null || $token !== $user->getToken() || !$this->isRequestInTime($user->getPasswordRequestedAt()))
{
throw new AccessDeniedHttpException();
}
$form = $this->createForm(ResettingType::class, $user);
$form->handleRequest($request);
if($form->isSubmitted() && $form->isValid())
{
$password = $passwordEncoder->encodePassword($user, $user->getPlainPassword());
$user->setPassword($password);
// réinitialisation du token à null pour qu'il ne soit plus réutilisable
$user->setToken(null);
$user->setPasswordRequestedAt(null);
$em = $this->getDoctrine()->getManager();
$em->persist($user);
$em->flush();
$request->getSession()->getFlashBag()->add('success', "Votre mot de passe a été modifié.");
return $this->redirectToRoute('security_login_form');
}
return $this->render('security/resetting.html.twig', [
'form' => $form->createView()
]);
}
}
Я новичок в Symfony, поэтому я могу упустить что-то очевидное ... Я просто не вижу этого заранее, lol thx