Security(セキュリティ)

【WordPress】antispambot()でメールアドレスをエンティティ化

antispambot()でメールアドレスをエンティティ化

WordPressでメールアドレスを表示させる場合には、antispambot()エンティティ化して出力します。

メールアドレスをエンティティ化することで、スパムボットに収集されにくくするためです。
スパムメールが大量に送られてくるのは困りますからね!

使い方は、こんな感じです。
<?php echo antispambot("メールアドレス"); ?>

例えば、
<?php echo antispambot("info@example.com"); ?>
を実行すると、このようにメールアドレスを暗号化することが出来ます。
メールアドレスのエンティティ化

具体的には、以下の様な使い方が出来ますね。

<a href="mailto:<?php echo antispambot("info@example.com "); ?>"><?php echo antispambot("info@example.com "); ?></a>

もし、投稿者のメールアドレスを表示させる場合には、このように書くことも出来ますね。

<?php echo antispambot( get_the_author_email() ); ?>

 

記事投稿画面(エディタ)で使用する場合

記事の投稿画面にメールアドレスを貼り付ける場合には、
ショートコード化しておくと便利です。

ショートコードには、自己完結型囲み型があります。

 

自己完結型ショートコード

自己完結型のショートコードを書くのであれば、このようになります。

function antispambot_shortcode($atts){
extract(shortcode_atts(array(
"mailto" => "",
"txt" => ""
), $atts));
if( is_email($txt) ) $txt = antispambot($txt);
return "<a href=\"mailto:" . antispambot($mailto) . "\">" . esc_html(antispambot($txt)) ."</a>";
}
add_shortcode("email", "antispambot_shortcode");

使い方は、このようになります。
[email mailto="info@example.com" txt="お問合せはこちらから"]

[email mailto="info@example.com" txt="info@example.com"]

 

囲み型ショートコード

囲み型のショートコードを書くのであれば、このようになります。

function antispambot_shortcode($atts, $mailto = null){
if( !is_email($mailto) ) return;
return "<a href=\"mailto:" . antispambot($mailto) . "\">" . esc_html(antispambot($mailto)) ."</a>";
}
add_shortcode("email", "antispambot_shortcode");

もし、
リンクなしで表示したい場合には、
return "<a href=\"mailto:" . antispambot($mailto) . "\">" . esc_html(antispambot($mailto)) ."</a>";

return antispambot($mailto);
に変更してください。

使い方は、このようになります。
[email]info@example.com[/email]

この記事を書いている人
株式会社ディープ
名前足立拓也

メールアドレスadachi@deep-deep.jp

関連記事

最近の記事

  1. ドメインについて
  2. WP:WordPress(ワードプレス)
  3. URL設計(URLデザイン)
  4. URL「ディレクトリ名」と文字アンダースコア(_)とハイフン(-)
  5. SEO対策(外部ファイルの読み込み)
  6. URL リダイレクト
  7. インデックスされない
  8. 内部対策は必要?
  9. CMS(シーエムエス)
  10. SEO業者は必要?

Twitter

アーカイブ

PAGE TOP