この記事は最後に更新してから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


お勧め

wp_insert_user(2019年5月29日 更新)

mixed wp_insert_user( mixed $userdata )
ユーザーを登録する。

fetch_feed(2018年5月27日 更新)

mixed fetch_feed( mixed $url )
RSSまたはAtom形式のフィードデータを読み込む。

is_tag(2018年5月27日 更新)

bool is_tag( [ mixed $slug = '' ] )
要求されているページが、タグアーカイブページか調べる。

esc_js(2019年1月24日 更新)

string esc_js( string $text )
文字列をインラインJavaScript向けにエスケープ処理する。

wp_list_pages(2015年4月28日 更新)

string wp_list_pages( [ mixed $args = '' ] )
固定ページを一覧表示する。