Laravel:电子邮件的自定义验证

标签 laravel email laravel-5.3

当有人注册时,我只想从一台服务器说“@ myemail.com”接受邮件ID。如果提供了其他任何邮件地址,则会显示您的邮件ID无效。我应该怎么办??

   protected function validator(array $data)
  {
    return Validator::make($data, [
        'name' => 'required|max:255',
        'email' => 'required|email|max:255|unique:users',
        'password' => 'required|min:6|confirmed',
        /*'usertype' => 'required',*/
     ]);
  }

它是我的注册控制者的验证者

最佳答案

您可以为此使用正则表达式模式。将此附加到您的电子邮件验证中:

protected function validator(array $data)
{
    return Validator::make($data, [
        'name' => 'required|max:255',
        'email' => 'required|email|max:255|regex:/(.*)@myemail\.com/i|unique:users',
        'password' => 'required|min:6|confirmed',
        /*'usertype' => 'required',*/
     ]);
}

编辑
对于多个域,由于两个邮件域之间存在管道,因此必须在验证中使用数组:
'email' => ['required', 'max:255', 'email', 'regex:/(.*)@(mrbglobalbd|millwardbrown)\.com/i', 'unique:users'],

Note: When using the regex pattern, it may be necessary to specify rules in an array instead of using pipe delimiters, especially if the regular expression contains a pipe character.

关于Laravel:电子邮件的自定义验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41933019/

相关文章:

email - X 天后重新发送硬退回电子邮件的最佳做法

laravel - 为什么这个 Laravel 5.4 服务提供者不注册?

mysql - Laravel5.3 连接并同步多个数据库

php - 使用正则表达式使菜单项在 laravel adminlte 中处于事件状态

email - 使用 EC2 或网络邮件/电子邮件服务提供商的 AWS Route 53 电子邮件设置

laravel - Twitter OAuth 访问 token 错误 : Request token missing

javascript - 这个 Javascript 以前可以工作,但现在不行了

php - ID 列的 Laravel 访问器

php - 同一模型上的 Laravel 多对多关系

php - Laravel 缓存与 Redis 非常慢