この記事は最後に更新してから1年以上経過しています。

Emojin:プラグイン作ってみました

説明

ちょっと前のTLでiOSの絵文字を含んだ投稿を保存すると、絵文字以降の文章がすべて消えた状態で保存されるといったツイートを見かけた。少し検索してみると、MySQLのデータベースの文字セットが「utf8」の場合、iOSの絵文字のような4バイトの文字を正常に保存できず、それ以降の文章も保存されないというものらしい。対処方法としてデータベースの文字セットを「utf8mb4」に変更するのが有効らしいのだが、他に回避策がないか考えてみた。

基本的なアプローチは、UTF-8の4バイト文字が保存できないのだから、それを何かに置き換えてあげればいいというもの。問題は何に置き換えるのが適切なのかということで、いろいろ試した結果、対象の文字を「数値文字参照」に置き換えるのがよいという結果に至った。そんなわけで作ったプラグインが、この「Emojin」となる。

インストールおよび使用方法

1. Emojinのアーカイブファイルを解凍し、フォルダごと /wp-content/plugins/ の中に入れてください。
最新のEmojinのアーカイブファイルは、「wordpress.org(43KB)(wordpress.orgは申請中)」からダウンロードしてください。
2. 管理ページのプラグインページで「Emojin」を有効にしてください。
管理者権限のアカウントでログインし、サイドナビの「プラグイン」をクリック。一覧の中から「Emojin」の「有効化」をクリックしてください。
3. iPadから絵文字を入力して、保存してみた。
絵文字がきっちり保存された「Emojin」を有効にする前は「絵文字」以降がなくなった状態で保存されていたが、「Emojin」を有効にした後は「絵文字」を含めてその後の文章もきちんと保存できるようになっている。

よくある質問

Q. mbstringは必要ですか。
A. 本プラグインではmbstringを使用しておらず、必要ではありません。

更新履歴

  • 2014.08.23 Emojin 0.1.0をリリースしました。

最終更新 : 2015年03月21日 15:31

お勧め

wp_authenticate(2022年1月31日 更新)

WP_User | WP_Error wp_authenticate( string $username, string $password )
ユーザー認証を行う。

wp_send_json_success(2020年12月10日 更新)

void wp_send_json_success( [ mixed $response = null [ , int $status_code = null [ , int $options = 0 ] ] ] )
AJAXリクエストの成功レスポンスとしてJSON情報を返す。

wp_oembed_get(2014年11月16日 更新)

mixed wp_oembed_get( string $url [ , mixed $args = '' ] )
oEmbedに対応したページの埋め込み用コンテンツを取得する。

setup_postdata(2014年11月16日 更新)

bool setup_postdata( stdClass $post )
投稿記事に関連するグローバル変数を設定する。

the_permalink(2018年5月27日 更新)

void the_permalink( [ mixed $post = 0 ] )
現在の投稿データのパーマリンクを表示する。