is_email()WP 0.71

Checks if the given string is an e-mail address.

Unreliable for strict email validation according to standards

  1. Does not fully check the format according to RFC – allows errors.
  2. Incorrectly handles subdomains – for example, [email protected] should be invalid (since 123.dot is an invalid subdomain name), but the function may return true.
1 time — 0.000105 sec (fast) | 50000 times — 0.14 sec (very fast)
Hooks from the function

Returns

String|false.

Usage

if( is_email( $email ) ){
	// this is an email...
}
$email(string) (required)
email to be checked.

Examples

2

#1 Demo

/// is_email() will pass the check:
var_dump( is_email( '[email protected]' ) );        // ✅ valid 
var_dump( is_email( '[email protected]' ) ); // punycode — ✅ valid
var_dump( is_email( '[email protected]' ) );        // bad subdomain — ❌ invalid

/// is_email() will not pass the check 
var_dump( is_email( 'юзер@домен.рф' ) );     // ❌ invalid (must be punycode)
var_dump( is_email( '[email protected]' ) );  // double dot — ❌ invalid
var_dump( is_email( '[email protected]' ) );  // hyphen at the beginning — ❌ invalid
var_dump( is_email( '[email protected]' ) );  // hyphen at the end — ❌ invalid
0

#2 Let's check if the email address is spelled correctly:

<?php
if ( is_email( '[email protected]' ) ) {
	  echo 'email address is correct.';
}
?>

Changelog

Since 0.71 Introduced.

is_email() code WP 7.0

function is_email( $email, $deprecated = false ) {
	if ( ! empty( $deprecated ) ) {
		_deprecated_argument( __FUNCTION__, '3.0.0' );
	}

	// Test for the minimum length the email can be.
	if ( strlen( $email ) < 6 ) {
		/**
		 * Filters whether an email address is valid.
		 *
		 * This filter is evaluated under several different contexts, such as 'email_too_short',
		 * 'email_no_at', 'local_invalid_chars', 'domain_period_sequence', 'domain_period_limits',
		 * 'domain_no_periods', 'sub_hyphen_limits', 'sub_invalid_chars', or no specific context.
		 *
		 * @since 2.8.0
		 *
		 * @param string|false $is_email The email address if successfully passed the is_email() checks, false otherwise.
		 * @param string       $email    The email address being checked.
		 * @param string       $context  Context under which the email was tested.
		 */
		return apply_filters( 'is_email', false, $email, 'email_too_short' );
	}

	// Test for an @ character after the first position.
	if ( false === strpos( $email, '@', 1 ) ) {
		/** This filter is documented in wp-includes/formatting.php */
		return apply_filters( 'is_email', false, $email, 'email_no_at' );
	}

	// Split out the local and domain parts.
	list( $local, $domain ) = explode( '@', $email, 2 );

	/*
	 * LOCAL PART
	 * Test for invalid characters.
	 */
	if ( ! preg_match( '/^[a-zA-Z0-9!#$%&\'*+\/=?^_`{|}~\.-]+$/', $local ) ) {
		/** This filter is documented in wp-includes/formatting.php */
		return apply_filters( 'is_email', false, $email, 'local_invalid_chars' );
	}

	/*
	 * DOMAIN PART
	 * Test for sequences of periods.
	 */
	if ( preg_match( '/\.{2,}/', $domain ) ) {
		/** This filter is documented in wp-includes/formatting.php */
		return apply_filters( 'is_email', false, $email, 'domain_period_sequence' );
	}

	// Test for leading and trailing periods and whitespace.
	if ( trim( $domain, " \t\n\r\0\x0B." ) !== $domain ) {
		/** This filter is documented in wp-includes/formatting.php */
		return apply_filters( 'is_email', false, $email, 'domain_period_limits' );
	}

	// Split the domain into subs.
	$subs = explode( '.', $domain );

	// Assume the domain will have at least two subs.
	if ( 2 > count( $subs ) ) {
		/** This filter is documented in wp-includes/formatting.php */
		return apply_filters( 'is_email', false, $email, 'domain_no_periods' );
	}

	// Loop through each sub.
	foreach ( $subs as $sub ) {
		// Test for leading and trailing hyphens and whitespace.
		if ( trim( $sub, " \t\n\r\0\x0B-" ) !== $sub ) {
			/** This filter is documented in wp-includes/formatting.php */
			return apply_filters( 'is_email', false, $email, 'sub_hyphen_limits' );
		}

		// Test for invalid characters.
		if ( ! preg_match( '/^[a-z0-9-]+$/i', $sub ) ) {
			/** This filter is documented in wp-includes/formatting.php */
			return apply_filters( 'is_email', false, $email, 'sub_invalid_chars' );
		}
	}

	// Congratulations, your email made it!
	/** This filter is documented in wp-includes/formatting.php */
	return apply_filters( 'is_email', $email, $email, null );
}