Laravel密码重置“No Sender”

时间:2016-04-03 15:12:45

标签: email laravel

当我在Laravel 5.1中进行密码重设时,我收到了电子邮件,但标题中显示“No Sender”。

有没有办法从某处为密码重置电子邮件指定发件人?除了发件人,我认为Laravel应该自动使用配置文件中指定的电子邮件设置?这很奇怪,因为当我将Laravel邮件配置设置为使用“邮件”驱动程序时,我收到退回的电子邮件,说我无法从动态地址发送(这在开发人员中可以预期),但密码重置电子邮件仍然通过。电子邮件重置不应该使用相同的配置设置吗?

4 个答案:

答案 0 :(得分:11)

杰克,您可以设置From的{​​{1}}属性和email id中的name属性。我也遇到了同样的问题,正如我上面提到的那样对它进行了分类。

答案 1 :(得分:5)

@SeriousJelly回答Laravel 5.2的更新

您的身份验证PasswordController覆盖resetEmailBuilder方法

中的

class PasswordController extends Controller
{
    protected function resetEmailBuilder()
    {
        return function (Message $message) {
            $message->subject($this->getEmailSubject());
            $message->from('you@email.com', 'you');
        };
    }
}

这可能有助于某人

答案 2 :(得分:3)

所以,Alexey Mezenin的答案几乎就在那里,然而,一个重要的不是覆盖核心文件,因为任何未来的更新都可能破坏功能。

由于您的PasswordController应该使用ResetsPassword特征,您应该只能覆盖ResetsPasswordPasswordController特征中的所有方法。

例如,将自己的fromsubject行添加到电子邮件中是一个简单的案例,可以在您的特征中查找相关功能,复制并粘贴到您的PasswordController中并进行修改。

以下是一个示例PasswordController,其函数覆盖了sendResetLinkEmail()函数。

<?php

namespace App\Http\Controllers\Auth;

use Illuminate\Http\Request;
use Illuminate\Mail\Message;
use Illuminate\Support\Facades\Password;
use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\ResetsPasswords;

class PasswordController extends Controller
{
    /*
    |--------------------------------------------------------------------------
    | Password Reset Controller
    |--------------------------------------------------------------------------
    |
    | This controller is responsible for handling password reset requests
    | and uses a simple trait to include this behavior. You're free to
    | explore this trait and override any methods you wish to tweak.
    |
    */

    use ResetsPasswords;

    /**
     * Create a new password controller instance.
     *
     * @return void
     */
    public function __construct()
    {
        $this->middleware('guest');
    }

    /**
     * Send a reset link to the given user.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     */
    public function sendResetLinkEmail(Request $request)
    {

        $this->validate($request, ['email' => 'required|email']);

        $broker = $this->getBroker();

        $response = Password::broker($broker)->sendResetLink($request->only('email'), function (Message $message) {
            $message->subject($this->getEmailSubject());
            $message->from(env('MAIL_FROM'), env('APP_NAME'));
        });

        switch ($response) {
            case Password::RESET_LINK_SENT:
                return $this->getSendResetLinkEmailSuccessResponse($response);

            case Password::INVALID_USER:
            default:
                return $this->getSendResetLinkEmailFailureResponse($response);
        }
    }

答案 3 :(得分:0)

也许有更好的解决方案,但您可以在此行之后手动将代码添加到\vendor\laravel\framework\src\Illuminate\Foundation\Auth\ResetPasswords.php

$message->subject($this->getEmailSubject()); // this is line 66

添加如下内容:

$message->from('my@email.com', 'My Site');

https://laravel.com/docs/5.1/mail#sending-mail