我正在尝试对现有Symphony应用程序实施忘记密码功能。到目前为止,我已完成密码请求。用户放入电子邮件,并使用令牌发送电子邮件。返回网址看起来像这样:
/ intranet / password-change / f74eab6dca8b5ed6fd46e7893221254b655f94799589e0b83c
通常应该显示一个形式,但是当我访问该URL时,我会收到此消息:
App \ Controller \ ResetController类不存在 / 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的新手,所以我可能会错过一些明显的东西……我只是看不到它而已
答案 0 :(得分:2)
Just将AppBundle替换为App
namespace AppBundle\Controller;
答案 1 :(得分:0)
我也有同样的问题。
我将 ns 更改为 AppBundle\Controller
,导致另一个错误:
Compile Error: Cannot declare class AppBundle\Controller\MyController, because the name is already in use
。