2012-09-25 32 views

回答

9

這裏有幾個我使用的功能。

第一個使用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; 
} 

例子:

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

第二個將返回鏈接,電子郵件地址是HTML和URL編碼:

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; 
} 

例如:

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

有趣的方法+1。但它可能有一些兼容性問題。 –

+0

我沒有在Safari和移動瀏覽器中測試過它。 FF,IE,Chrome都不錯。 –

+0

行 - 請試試:-) –

12

我的最愛:

標記+ PHP

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

CSS

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

Fiddle

+1

太棒了!任何想法如何複製/粘貼電子郵件? –

+0

@AakilFernandes看到小提琴:(( – moonwave99

+0

啊,那是我的擔心仍然是一個好的技巧 –

1

這裏有一個用PHP 7類型提示。

只是$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

這裏的另一種方式把它的情況下,有一個字符的主機前:

/** 
* @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); 
} 
相關問題