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

投稿内容のid属性などを保存するための対策

説明

WordPress 3.4にアップデートしたとある環境で投稿記事を保存すると、divタグなどのid属性がクリアされて保存するようになった(id属性が保存できなくなった)。ここでは、その対策方法の1つを紹介しておく。

投稿を保存すると、divタグのid属性がごっそり抜けおちた

今回の症状は、投稿内容を入力し、「公開」または「更新」ボタンを押した際に、投稿記事内のdivタグのid属性がなくなるというものである。自分の場合、偶然にも同じような症状を経験しており、ツボはわかっていたのでさっそく調査してみた。

id属性を取り除くのは、投稿情報を保存する wp_insert_post 関数で呼び出される sanitize_post 関数である。この関数の中では投稿情報に不適切な文字が含まれていないか調べ、不適切な情報を除外しており、今回の例ではid属性が不適切な情報とみなされたため、削除されたことになる。もう少し内部までトレースしていくと、実際に取り除いているのはcontent_save_preフィルターに登録された wp_filter_post_kses 関数だということがわかった。

これらのことを踏まえた対処方は、自テーマのfunctions.phpにて、admin_initアクションを登録し、その中でcontent_save_preフィルターから wp_filter_post_kses 関数を除外することになる $allowedposttags['div'] 配列に'id'を追加する。

add_action( 'admin_init', 'your_admin_init' );
if ( ! function_exists( 'your_admin_init' ) ) {
	function your_admin_init() {
		remove_filter('content_save_pre', 'wp_filter_post_kses');
		global $allowedposttags;
		$allowedposttags['div']['id'] = true;
	}
}

すでにadmin_initアクションを使っている場合は、その関数内に青字の remove_filter2行を追加するだけでいい。なお、この対処方法は、自社運営サイトで発生した症状の対処方法であり、同様の症状であっってもこの対応では対処できない可能性がある。その点についてはご了承していただきたい。


最終更新 : 2012年06月15日 21:04


お勧め

get_template(2011年9月8日 更新)

string get_template( )
現在のテーマ名を取得する。

paginate_links(2017年11月17日 更新)

mixed paginate_links( [ mixed $args = '' ] )
(アーカイブページ向けの)ページネートリンクを取得する。

wp_normalize_path(2018年7月6日 更新)

string wp_normalize_path( string $path )
パス名を標準化する。

load_textdomain(2018年5月27日 更新)

bool load_textdomain( string $domain, string $mofile )
国際化用ファイル(MOファイル)をロードする。

wp_upload_dir(2018年5月27日 更新)

array wp_upload_dir( [ string $time = null [ , bool $create_dir = true [ , bool $refresh_cache = false ] ] ] )
アップロードディレクトリ(パス名)を取得する。