解决wordpress 3.2版日志ID不连续问题

在主题的 functions.php 文件里面加入如下代码即可

/* 移除自动保存和修订版本 */
remove_action(‘pre_post_update’, ‘wp_save_post_revision’ );
add_action( ‘wp_print_scripts’, ‘disable_autosave’ );
function disable_autosave() {
        wp_deregister_script(‘autosave’);
}

原理是获取最早一条自动草稿作为当前文章使用,如此可以实现在原有自动草稿功能基础上保持文章ID连续,并去除了删除7天前自动草稿的功能。

依然是找到并打开 wp-adminincludespost.php 文件,找到 “if ($create_in_db) {” ,查找大约 418 至 427 行:

if ( $create_in_db ) {
    // Cleanup old auto-drafts more than 7 days old
    $old_posts = $wpdb->get_col( “SELECT ID FROM $wpdb->posts WHERE post_status = ‘auto-draft’ AND DATE_SUB( NOW(), INTERVAL 7 DAY ) > post_date” );//删除7天前自动草稿
    foreach ( (array) $old_posts as $delete )
        wp_delete_post( $delete, true ); // Force delete
    $post_id = wp_insert_post( array( ‘post_title’ => __( ‘Auto Draft’ ), ‘post_type’ => $post_type, ‘post_status’ => ‘auto-draft’ ) );
    $post = get_post( $post_id );
    if ( current_theme_supports( ‘post-formats’ ) && post_type_supports( $post->post_type, ‘post-formats’ ) && get_option( ‘default_post_format’ ) )
        set_post_format( $post, get_option( ‘default_post_format’ ) );
} else {

替换为

if ( $create_in_db ) {
    global $current_user;//获取当前登录管理用户
    $post = $wpdb->get_row( “SELECT * FROM $wpdb->posts WHERE post_status = ‘auto-draft’ AND post_type = ‘$post_type’ AND post_author = $current_user->ID ORDER BY ID ASC LIMIT 1″ );//获取最早一条自动草稿
    if ( !$post ) {
        $post_id = wp_insert_post( array( ‘post_title’ => __( ‘Auto Draft’ ), ‘post_type’ => $post_type, ‘post_status’ => ‘auto-draft’ ) );
        $post = get_post( $post_id );
    }
    if ( current_theme_supports( ‘post-formats’ ) && post_type_supports( $post->post_type, ‘post-formats’ ) && get_option( ‘default_post_format’ ) )
        set_post_format( $post, get_option( ‘default_post_format’ ) );
} else {

上面已经说明了方案的原理,请需要的童鞋结合代码注释看,解决方法是,如果数据库已经有不可见的自动草稿日志,那么点击添加新文章时,将不会再自动产生新的不可见自动草稿,而是直接调用最早的一篇不可见草稿作为当前文章所需的数据库记录来使用,同时为避免ID不连续,删除了“删除早于7天的自动草稿”的代码语句!

文章作者:H T S »» 来源网站:Have To Share
本文地址:解决wordpress 3.2版日志ID不连续问题 »» 短链:http://w.cpanle.com/?p=100
版权所有 © 转载时必须以链接形式注明作者和原始出处!

发表评论