Remove rewrite rules and then recreate rewrite rules.

This function is useful when used with custom post types as it allows for automatic flushing of the WordPress rewrite rules (usually needs to be done manually for new custom post types). However, this is an expensive operation so it should only be used when absolutely necessary. See Usage section for more details.

flush_rewrite_rules() 描述



  • Flushing the rewrite rules is an expensive operation, there are tutorials and examples that suggest executing it on the 'init' hook. This is bad practice.
  • Flush rules only on activation or deactivation, or when you know that the rewrite rules need to be changed. Don't do it on any hook that will triggered on a routine basis. More detail information in the comments on WP Engineer's post: Custom Post Type and Permalink
  • Make sure custom post types and taxonomies are properly registered before flushing rewrite rules, especially during plugin activation: Activation Checklist for WordPress Plugin Developers

<?php flush_rewrite_rules$hard ); ?>

flush_rewrite_rules() 用法



(boolean) (可选) Whether to update .htaccess (hard flush) or just update rewrite_rules transient (soft flush).

默认值: true (hard flush)

flush_rewrite_rules() 参数


This is how you would flush rewrite rules when a plugin is activated or deactivated:

/* ----------------------------------
 * wordpress之魂 © http://wphun.com
 * ---------------------------------- */

register_deactivation_hook( __FILE__, 'flush_rewrite_rules' );
register_activation_hook( __FILE__, 'myplugin_flush_rewrites' );
function myplugin_flush_rewrites() {
	// call your CPT registration function here (it should also be hooked into 'init')

This is how you would flush rules on theme activation:

/* ----------------------------------
 * wordpress之魂 © http://wphun.com
 * ---------------------------------- */
/* Flush rewrite rules for custom post types. */
add_action( 'after_switch_theme', 'flush_rewrite_rules' );

If you're developing a theme, while building it you can use this snippet of code that will flush rewrite rules when the file containing it is changed, or every 48 hours:

/* ----------------------------------
 * wordpress之魂 © http://wphun.com
 * ---------------------------------- */

// do not use on live/production servers
add_action( 'init','maybe_rewrite_rules' );
function maybe_rewrite_rules() {

	$ver = filemtime( __FILE__ ); // Get the file time for this file as the version number
	$defaults = array( 'version' => 0, 'time' => time() );
	$r = wp_parse_args( get_option( __CLASS__ . '_flush', array() ), $defaults );

	if ( $r['version'] != $ver || $r['time'] + 172800 < time() ) { // Flush if ver changes or if 48hrs has passed.
		// trace( 'flushed' );
		$args = array( 'version' => $ver, 'time' => time() );
		if ( ! update_option( __CLASS__ . '_flush', $args ) )
			add_option( __CLASS__ . '_flush', $args );


flush_rewrite_rules() 示例


添加于 版本: 3.0

flush_rewrite_rules() 历史


flush_rewrite_rules() 函数的代码位于 wp-includes/rewrite.php

/* ----------------------------------
 * wordpress之魂 © http://wphun.com
 * ---------------------------------- */
 * Remove rewrite rules and then recreate rewrite rules.
 * @since 3.0.0
 * @global WP_Rewrite $wp_rewrite
 * @param bool $hard Whether to update .htaccess (hard flush) or just update
 * 	                 rewrite_rules transient (soft flush). Default is true (hard).
function flush_rewrite_rules( $hard = true ) {
	global $wp_rewrite;
	$wp_rewrite->flush_rules( $hard );

flush_rewrite_rules() 源文件