WordPress设置文章只允许搜索引擎查看
日期:
标签:WordPress教程
如需帮忙改代码,或者WordPress二次开发、PHP网站建设等需求,可联系我购买付费服务: 点此联系我
泡泡龙 留言说,有这样的一种需求:有些文章只是为了SEO才发布的,想让这些文章只允许搜索引擎抓取,普通的访客无法查看,在WordPress中如何做到?
实现代码
如果你的WordPress站点未开启页面缓存,这个需求也不难实现,我们可以参考之前写的 WordPress 对搜索引擎隐藏特定的文章 中的代码,稍作修改即可。在当前主题的functions.php中添加以下php代码,用UTF8编码保存:
// 给文章和页面的编辑页添加选项
function ludouseo_add_custom_box() {
add_meta_box('ludou_se_only', '搜索引擎专属', 'ludou_se_only', 'post', 'side', 'low');
add_meta_box('ludou_se_only', '搜索引擎专属', 'ludou_se_only', 'page', 'side', 'low');
}
add_action('add_meta_boxes', 'ludouseo_add_custom_box');
function ludou_se_only() {
global $post;
//添加验证字段
wp_nonce_field('ludou_se_only', 'ludou_se_only_nonce');
$meta_value = get_post_meta($post->ID, 'ludou_se_only', true);
if($meta_value)
echo '<input name="ludou-se-only" type="checkbox" checked="checked" value="1" /> 只允许搜索引擎查看';
else
echo '<input name="ludou-se-only" type="checkbox" value="1" /> 只允许搜索引擎查看';
}
// 保存选项设置
function ludouseo_save_postdata($post_id) {
// 验证
if ( !isset( $_POST['ludou_se_only_nonce']))
return $post_id;
$nonce = $_POST['ludou_se_only_nonce'];
// 验证字段是否合法
if (!wp_verify_nonce( $nonce, 'ludou_se_only'))
return $post_id;
// 判断是否自动保存
if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE)
return $post_id;
// 验证用户权限
if ('page' == $_POST['post_type']) {
if ( !current_user_can('edit_page', $post_id))
return $post_id;
}
else {
if (!current_user_can('edit_post', $post_id))
return $post_id;
}
// 更新设置
if(!empty($_POST['ludou-se-only']))
update_post_meta($post_id, 'ludou_se_only', '1');
else
delete_post_meta($post_id, 'ludou_se_only');
}
add_action('save_post', 'ludouseo_save_postdata');
function do_ludou_se_only() {
// 本功能只对文章和页面有效
if(is_singular()) {
global $post;
$is_robots = 0;
$ludou_se_only = get_post_meta($post->ID, 'ludou_se_only', true);
if(!empty($ludou_se_only)) {
// 下面是搜索引擎Agent判断关键字数组
// 有点简单,自己优化一下吧
$bots = array(
'spider',
'bot',
'crawl',
'Slurp',
'yahoo-blogs',
'Yandex',
'Yeti',
'blogsearch',
'ia_archive',
'Google'
);
$useragent = $_SERVER['HTTP_USER_AGENT'];
if(!empty($useragent)) {
foreach ($bots as $lookfor) {
if (stristr($useragent, $lookfor) !== false) {
$is_robots = 1;
break;
}
}
}
// 如果不是搜索引擎,就显示错误信息
// 已登录的用户不受影响
if(!$is_robots && !is_user_logged_in()) {
wp_die('您无权查看此文!');
}
}
}
}
add_action('wp', 'do_ludou_se_only');
使用方法
成功添加以上代码到当前主题的functions.php后,我们就可以正常使用了,完全傻瓜式。在WordPress后台文章和页面的编辑页面,右边栏底部我们可以看到这样的选框:
如果当前文章/页面需要禁止搜索引擎抓取,勾选即可。勾选后,当此文章/页面被普通访客访问时就会显示下面的错误信息(搜索引擎和已登录用户不受影响):
-- 完 --
本文采用 「CC BY-NC-SA 4.0」创作共享协议,转载请标注以下信息:
原文出处:露兜即刻 https://www.ludou.org/wordpress-post-for-search-engine-only.html
不想让访客看文章,那又让搜索引擎抓取有什么意义呢
露兜老师,我把您写的代码复制了一下,测试,不行呢.总是出错,不知道是怎么回事?
@泡泡龙 只说出错,不说错误提示内容的行为都是耍流氓。
这个算是黑帽做法了吧。
@新一 应该是,至少我是不用。不过有人做实验,然后我们想用实验结果未必不好。
@新一 我更乐意发些文章在某些分类。。而不显示在首页。
不好意思,露兜老师,我直接没搞懂,我也没看出有错误提示,但是全是乱码,这里上不了图片,我给您发封邮件吧,里面有截图.
@泡泡龙 未收到任何邮件。
中文乱码请使用utf8编码保存,具体怎么操作请上网搜索。
或者把第3、4、16、18行代码中的中文改成你能看懂的拼音或英文。
@泡泡龙 文中的代码请复制到functions.php的第一个<?php下面任意空行中
有项目付费找你做 ,QQ给你留言和邮件你收到没? 看到我的留言,请回复下哈。之前有找你做过好几次的哈。
大家都习惯做黑盒啊。。
关注下了,技术性博客哈哈~
真是高手,直接在wordpress后台加属性选项,强
黑帽还是不做了
我想问一下,每次复制这个代码都会带上前面的数字,用其它浏览器复制每行代码前都有一段空格怎么办Q.Q
@小龙的音乐房 IE下会有这样的问题。目前在修复中。
这个东西也是会被蜘蛛认为是作弊的
@每日秀 所以慎用
既然让搜索引擎查看,那么普通人也能看到啊,别忘了还有快照。
比起欺骗访客跟蜘蛛进行不同内容展现。这个手段不错