カスタムの投稿タイプ書き換えルールを追加する場合、カバーすべき攻撃ポイントは2つあります。
書き換えルール
これは、リライトルールがで生成されているときに発生wp-includes/rewrite.php
しWP_Rewrite::rewrite_rules()
ます。WordPressでは、投稿、ページ、さまざまな種類のアーカイブなどの特定の要素の書き換えルールをフィルター処理できます。表示さposttype_rewrite_rules
れるposttype
部分は、カスタム投稿タイプの名前です。あるいはpost_rewrite_rules
、標準の投稿ルールも削除しない限り、フィルターを使用できます。
次に、実際に書き換えルールを生成する関数が必要です。
// add our new permastruct to the rewrite rules
add_filter( 'posttype_rewrite_rules', 'add_permastruct' );
function add_permastruct( $rules ) {
global $wp_rewrite;
// set your desired permalink structure here
$struct = '/%category%/%year%/%monthnum%/%postname%/';
// use the WP rewrite rule generating function
$rules = $wp_rewrite->generate_rewrite_rules(
$struct, // the permalink structure
EP_PERMALINK, // Endpoint mask: adds rewrite rules for single post endpoints like comments pages etc...
false, // Paged: add rewrite rules for paging eg. for archives (not needed here)
true, // Feed: add rewrite rules for feed endpoints
true, // For comments: whether the feed rules should be for post comments - on a singular page adds endpoints for comments feed
false, // Walk directories: whether to generate rules for each segment of the permastruct delimited by '/'. Always set to false otherwise custom rewrite rules will be too greedy, they appear at the top of the rules
true // Add custom endpoints
);
return $rules;
}
あなたが遊びたいと思った場合、ここで注意すべき主なものは「ウォークディレクトリ」ブール値です。パーマ構造の各セグメントに対して書き換えルールを生成し、書き換えルールの不一致を引き起こす可能性があります。WordPress URLが要求されると、書き換えルールの配列が上から下にチェックされます。一致が見つかるとすぐに、見つかったものがすべてロードされます。たとえば、パーマ構造に貪欲な一致がある場合などです。以下のための/%category%/%postname%/
ディレクトリや散歩の両方の出力書き換えルールますそこにある/%category%/%postname%/
と/%category%/
これは何もマッチします。それが早すぎる場合は、台無しです。
パーマリンク
これは、投稿タイプのパーマリンクを解析し、パーマ構造(例: '/%year%/%monthnum%/%postname%/')を実際のURLに変換する関数です。
次のパートは、理想的にはにあるget_permalink()
関数のバージョンの単純な例ですwp-includes/link-template.php
。カスタムポストパーマリンクはによって生成さget_post_permalink()
れたのかなり骨抜きバージョンですget_permalink()
。get_post_permalink()
によってフィルタリングされるpost_type_link
ため、カスタムパーマ構造を作成するためにそれを使用しています。
// parse the generated links
add_filter( 'post_type_link', 'custom_post_permalink', 10, 4 );
function custom_post_permalink( $permalink, $post, $leavename, $sample ) {
// only do our stuff if we're using pretty permalinks
// and if it's our target post type
if ( $post->post_type == 'posttype' && get_option( 'permalink_structure' ) ) {
// remember our desired permalink structure here
// we need to generate the equivalent with real data
// to match the rewrite rules set up from before
$struct = '/%category%/%year%/%monthnum%/%postname%/';
$rewritecodes = array(
'%category%',
'%year%',
'%monthnum%',
'%postname%'
);
// setup data
$terms = get_the_terms($post->ID, 'category');
$unixtime = strtotime( $post->post_date );
// this code is from get_permalink()
$category = '';
if ( strpos($permalink, '%category%') !== false ) {
$cats = get_the_category($post->ID);
if ( $cats ) {
usort($cats, '_usort_terms_by_ID'); // order by ID
$category = $cats[0]->slug;
if ( $parent = $cats[0]->parent )
$category = get_category_parents($parent, false, '/', true) . $category;
}
// show default category in permalinks, without
// having to assign it explicitly
if ( empty($category) ) {
$default_category = get_category( get_option( 'default_category' ) );
$category = is_wp_error( $default_category ) ? '' : $default_category->slug;
}
}
$replacements = array(
$category,
date( 'Y', $unixtime ),
date( 'm', $unixtime ),
$post->post_name
);
// finish off the permalink
$permalink = home_url( str_replace( $rewritecodes, $replacements, $struct ) );
$permalink = user_trailingslashit($permalink, 'single');
}
return $permalink;
}
前述のように、カスタム書き換えルールセットとパーマリンクを生成するための非常に単純化されたケースであり、特に柔軟性はありませんが、開始するには十分なはずです。
不正行為
カスタム投稿タイプ%category%
のパーマ構造を定義できるプラグインを作成しましたが、投稿のパーマリンク構造で使用できるように、自分のプラグインがサポート%custom_taxonomy_name%
するカスタム分類もサポートしていcustom_taxonomy_name
ます。%club%
。
階層的/非階層的分類法で期待どおりに機能します。
http://wordpress.org/extend/plugins/wp-permastructure/