Адрес в почтовом ящике, указанный [Doctrine \ ORM \ Query_state], не соответствует RFC 2822, 3.6.2 - PullRequest
0 голосов
/ 28 июня 2018

Я занимаюсь разработкой блога под symfony и для отправки писем использую swiftMailer.

Я использую этот код в своем контроллере для отправки всем своим пользователям, чтобы предупредить их, что добавлена ​​новая статья, но проблема в том, что она показывает мне сообщение об ошибке.

Мой контроллер:

/**
 * @Route("/admin/ajout")
 * @param  Request $request
 * @return Response
 * @throws \Exception
 */

 public function add(Request $request, \Swift_Mailer $mailer): Response {

    $article = new Articles();
    $addArticle = $this->createForm(ArticlesType::class, $article);
    $addArticle->handleRequest($request);

    $info = $this->getDoctrine()->getRepository(InfoMore::class)->findByInfo(2);

     $em    = $this->get('doctrine.orm.entity_manager');
     $dql   = "SELECT email FROM App:user";
     $query = $em->createQuery($dql);

    if($addArticle->isSubmitted() && $addArticle->isValid()) {

        $article = $addArticle->getData();
        $manager = $this->getDoctrine()->getManager();
        $manager->persist($article);
        $manager->flush();

        $message = (new \Swift_Message('Un nouvelles articles est publier'))
            ->setFrom('contact@al-houria.com')
            ->setTo($query)
            ->setBody(
                $this->renderView(
                    'email/article_publish.html.twig'
                ),
                'text/html'
            )
        ;
        $mailer->send($message);

        $this->addFlash('article', 'L\'article a bien étais ajouter');
        return $this->redirectToRoute('app_backoffice_admin');
    }

    return $this->render('backOffice/CRUD/add.html.twig', [
        'title' => 'Ajouter un article a votre blog',
        'info' => $info,
        'addArticle' => $addArticle->createView()
    ]);

 } 

и сообщение об ошибке:

Адрес в почтовом ящике, указанный [Doctrine \ ORM \ Query_state], не соответствует RFC 2822, 3.6.2

Он сообщает, что адрес недействителен, и как в этом случае добавить несколько адресов электронной почты?

Спасибо за вашу помощь!

1 Ответ

0 голосов
/ 28 июня 2018

Предполагая, что ваша сущность User находится в App\Entity\User, вы можете выбрать это:

$emails = $em
    ->createQuery('SELECT u.email FROM App\Entity\User u')
    ->getResult()
;

Это вернет массив адресов электронной почты от ваших пользователей. Затем вы просто передаете это своему setTo() методу:

$message = (new \Swift_Message('Un nouvelles articles est publier'))
    ->setFrom('contact@al-houria.com')
    ->setTo($emails)
    // ...
;

См. Doctrine Примеры DQL SELECT для получения дополнительной помощи. Если вы хотите быть немного более изобретательным, вы можете добавить имя пользователя к его адресам электронной почты и отправить его. Предположим, у вас есть функция getName() в вашей пользовательской сущности. Вместо этого вы можете сгенерировать свои адреса электронной почты, например:

$emails = [];
$users = $this->getDoctrine()->getRepository(User::class)->findAll();

foreach ($users as $user) {
    $emails[$user->getEmail()] = $user->getName();
}

Тогда, когда вы позвоните ->setTo($emails), у него будет и имя, и адрес электронной почты.

Последнее замечание, я бы использовал $em = $this->getDoctrine()->getManager(); вместо $this->get('doctrine.orm.entity_manager');

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...