2012-09-25 13 views

Respuesta

9

Aquí hay un par de funciones que uso.

Primero uno ofusca dirección de correo electrónico utilizando los códigos de caracteres HTML:

function getObfuscatedEmailAddress($email) 
{ 
    $alwaysEncode = array('.', ':', '@'); 

    $result = ''; 

    // Encode string using oct and hex character codes 
    for ($i = 0; $i < strlen($email); $i++) 
    { 
     // Encode 25% of characters including several that always should be encoded 
     if (in_array($email[$i], $alwaysEncode) || mt_rand(1, 100) < 25) 
     { 
      if (mt_rand(0, 1)) 
      { 
       $result .= '&#' . ord($email[$i]) . ';'; 
      } 
      else 
      { 
       $result .= '&#x' . dechex(ord($email[$i])) . ';'; 
      } 
     } 
     else 
     { 
      $result .= $email[$i]; 
     } 
    } 

    return $result; 
} 

Ejemplo:

echo getObfuscatedEmailAddress('[email protected]'); 
--> 
firstn&#x61;m&#x65;&#x2e;la&#115;t-name&#x40;examp&#108;e&#46;&#x63;om 

segundo volverá enlace donde dirección de correo electrónico está HTML y URL codificada:

function getObfuscatedEmailLink($email, $params = array()) 
{ 
    if (!is_array($params)) 
    { 
     $params = array(); 
    } 

    // Tell search engines to ignore obfuscated uri 
    if (!isset($params['rel'])) 
    { 
     $params['rel'] = 'nofollow'; 
    } 

    $neverEncode = array('.', '@', '+'); // Don't encode those as not fully supported by IE & Chrome 

    $urlEncodedEmail = ''; 
    for ($i = 0; $i < strlen($email); $i++) 
    { 
     // Encode 25% of characters 
     if (!in_array($email[$i], $neverEncode) && mt_rand(1, 100) < 25) 
     { 
      $charCode = ord($email[$i]); 
      $urlEncodedEmail .= '%'; 
      $urlEncodedEmail .= dechex(($charCode >> 4) & 0xF); 
      $urlEncodedEmail .= dechex($charCode & 0xF); 
     } 
     else 
     { 
      $urlEncodedEmail .= $email[$i]; 
     } 
    } 

    $obfuscatedEmail = getObfuscatedEmailAddress($email); 
    $obfuscatedEmailUrl = getObfuscatedEmailAddress('mailto:' . $urlEncodedEmail); 

    $link = '<a href="' . $obfuscatedEmailUrl . '"'; 
    foreach ($params as $param => $value) 
    { 
     $link .= ' ' . $param . '="' . htmlspecialchars($value). '"'; 
    } 
    $link .= '>' . $obfuscatedEmail . '</a>'; 

    return $link; 
} 

Ejemplo:

echo getObfuscatedEmailLink('[email protected]'); 
--> 
<a href="mailt&#111;&#58;%66i&#37;72stna%&#54;d&#x65;&#46;&#37;6c&#x25;6&#x31;st&#x2d;name&#64;&#101;&#x78;&#x61;mple&#46;co&#109;" rel="nofollow">f&#x69;&#114;s&#x74;na&#109;e&#x2e;&#108;a&#x73;t-name&#64;e&#x78;ample&#46;co&#109;</a> 
+0

Enfoque interesante +1. Pero podría tener algunos problemas de compatibilidad. –

+0

No lo he probado en Safari y navegadores móviles. FF, IE, Chrome son buenos. –

+0

OK - lo intentaré :-) –

12

Mi favorito:

marcado + PHP

<span class="rev"><?php echo strrev($email); ?> </span> 

CSS

.rev{ 
    direction: rtl; 
    unicode-bidi: bidi-override; 
} 

Fiddle

+1

¡Brillante! ¿Alguna idea de cómo se mantiene esto al copiar/pegar correos electrónicos? –

+0

@AakilFernandes ver violín: (( – moonwave99

+0

Ah, esa era mi preocupación Todavía un buen truco –

1

Aquí está uno con PHP 7 tipo de insinuación

a llamarlo con $this->obfuscateEmail($email);

/** 
* @param string $email 
* @return string 
*/ 
private function obfuscateEmail(string $email) : string 
{ 
    $em = explode("@", $email); 
    $name = implode(array_slice($em, 0, count($em) - 1), '@'); 
    $len = floor(strlen($name)/2); 

    return substr($name, 0, $len) . str_repeat('*', $len) . "@" . end($em); 
} 
0

Aquí una forma alternativa en caso de que haya un carácter antes de host:

/** 
* @param string $email 
* @return string 
*/ 

private function obfuscateEmail($email) 
{ 
    $em = explode("@", $email); 

    $name = implode(array_slice($em, 0, count($em)-1), '@'); 

    if(strlen($name)==1){ 
     return '*'.'@'.end($em); 
    } 

    $len = floor(strlen($name)/2); 

    return substr($name,0, $len) . str_repeat('*', $len) . "@" . end($em); 
} 
Cuestiones relacionadas