WordPress无插件自动检测标题是否重复被发布问题
ssr
撰写于 2022年 02月 26 日

无论我们是个人网站,还是较大的内容类型网站,在更新的内容中特别容易出现内容和标题的重复。内容重复肯定不是特别的好啊,所以我们在使用WordPress的时候可以用插件或者是无插件形式在更新内容的时候检测是否重复,有重复的时候可以提醒我们。
第一、脚本内容


// 发表文章页面,前端抓取标题并使用AJAX发送请求
add_action( 'admin_print_footer_scripts', 'duplicate_titles_enqueue_scripts', 100 );
function duplicate_titles_enqueue_scripts() {
?>

<?php
}
// 接收前端ajax参数
add_action('wp_ajax_title_checks', 'duplicate_title_checks_callback');
function duplicate_title_checks_callback(){
global $wpdb;<br> $title = $_POST['post_title'];<br> $post_id = $_POST['post_id'];<br> $titles = "SELECT post_title FROM $wpdb->posts WHERE post_status = 'publish' AND post_type = 'post'<br> AND post_title = '{$title}' AND ID != {$post_id} ";<br> $results = $wpdb->get_results($titles);
if($results) {
echo "". _( '此标题已存在,请换一个标题!' , '' ) ." ";
} else {
echo ''._('恭喜,此标题未与其他文章标题重复!' , '').'';
}
die();
}
// 检测后端标题并且避免同名文章更新草稿
add_action( 'publish_post','duplicate_titles_wallfa_bc' ) ;
function duplicate_titles_wallfa_bc( $post ){<br> global $wpdb ;
$title = $_POST['post_title'] ;
$post_id = $post ;
$wtitles = "SELECT post_title FROM $wpdb->posts WHERE post_status = 'publish' AND post_type = 'post'
AND post_title = '{$title}' AND ID != {$post_id} " ;
$wresults = $wpdb->get_results( $wtitles ) ;<br> if ( $wresults ){
$wpdb->update( $wpdb->posts, array( 'post_status' =>
'draft' ), array( 'ID' => $post ) ) ;<br> $arr_params = array( 'message' => '10', 'wallfaerror' => '1' ) ;
$location = add_query_arg( $arr_params , get_edit_post_link( $post , 'url' ) ) ;<br> wp_redirect( $location ) ;
exit ;
}
}
/// 文章提交更新后的提示
add_action( 'admin_notices', 'not_published_error_notice' );
function not_published_error_notice() {
if(isset($_GET['wallfaerror']) == 1 ){
?>

<?php _e('貌似已经存在相同标题的文章,若您使用了文章别名作为固定链接,则可以通过修改本文的固定链接来使标题不再重复!' , '') ?>



<?php
}
}
// 禁用自动保存
add_action( 'wp_print_scripts', 'disable_autosave' ) ;
function disable_autosave(){
wp_deregister_script( 'autosave' ) ;
}

第二、添加方法
将脚本添加到当前主题的Functions.php文件中。
本文脚本来自:http://www.inlojv.com/5431.html

WordPress无插件自动检测标题是否重复被发布问题

无论我们是个人网站,还是较大的内容类型网站,在更新的内容中特别容易出现内容和标题的重复。内容重复肯定不是特别的好啊,所以我们在使用WordPress的时候可以用插件或者是无插件形式在更新内容的时候检测是否重复,有重复的时候可以提醒我们。
第一、脚本内容


// 发表文章页面,前端抓取标题并使用AJAX发送请求
add_action( 'admin_print_footer_scripts', 'duplicate_titles_enqueue_scripts', 100 );
function duplicate_titles_enqueue_scripts() {
?>

<?php
}
// 接收前端ajax参数
add_action('wp_ajax_title_checks', 'duplicate_title_checks_callback');
function duplicate_title_checks_callback(){
global $wpdb;<br> $title = $_POST['post_title'];<br> $post_id = $_POST['post_id'];<br> $titles = "SELECT post_title FROM $wpdb->posts WHERE post_status = 'publish' AND post_type = 'post'<br> AND post_title = '{$title}' AND ID != {$post_id} ";<br> $results = $wpdb->get_results($titles);
if($results) {
echo "". _( '此标题已存在,请换一个标题!' , '' ) ." ";
} else {
echo ''._('恭喜,此标题未与其他文章标题重复!' , '').'';
}
die();
}
// 检测后端标题并且避免同名文章更新草稿
add_action( 'publish_post','duplicate_titles_wallfa_bc' ) ;
function duplicate_titles_wallfa_bc( $post ){<br> global $wpdb ;
$title = $_POST['post_title'] ;
$post_id = $post ;
$wtitles = "SELECT post_title FROM $wpdb->posts WHERE post_status = 'publish' AND post_type = 'post'
AND post_title = '{$title}' AND ID != {$post_id} " ;
$wresults = $wpdb->get_results( $wtitles ) ;<br> if ( $wresults ){
$wpdb->update( $wpdb->posts, array( 'post_status' =>
'draft' ), array( 'ID' => $post ) ) ;<br> $arr_params = array( 'message' => '10', 'wallfaerror' => '1' ) ;
$location = add_query_arg( $arr_params , get_edit_post_link( $post , 'url' ) ) ;<br> wp_redirect( $location ) ;
exit ;
}
}
/// 文章提交更新后的提示
add_action( 'admin_notices', 'not_published_error_notice' );
function not_published_error_notice() {
if(isset($_GET['wallfaerror']) == 1 ){
?>

<?php _e('貌似已经存在相同标题的文章,若您使用了文章别名作为固定链接,则可以通过修改本文的固定链接来使标题不再重复!' , '') ?>



<?php
}
}
// 禁用自动保存
add_action( 'wp_print_scripts', 'disable_autosave' ) ;
function disable_autosave(){
wp_deregister_script( 'autosave' ) ;
}

第二、添加方法
将脚本添加到当前主题的Functions.php文件中。
本文脚本来自:http://www.inlojv.com/5431.html

赞 (0)

猜您想看

评论区(暂无评论)

这里空空如也,快来评论吧~

我要评论