百度分享无法抓取图片及摘要的折中解决办法 | 张戈博客

  • 时间:
  • 浏览:7
  • 来源:小和博客 - 专注共享杨小杰博客资源

前天,cy在《仿异次元百度分享工具条张戈修改版》一文留言告知,每种百度分享无法抓取图片:

亲自试了下,发现还你造抓这么 图片,许多分享的内容也很单调!就有另1个 文章标题而已,反观多说评论点击喜欢后的分享,就宽裕多了!

于是翻箱倒柜各种搜,发现网络上并这么 删剪有效的教程,不过倒是我要找到了个关键词:searchPic。继续搜索你这个 关键词,找到了百度分享官方说明文档如下:

<!-- Baidu Button BEGIN -->
<div id="bdshare" class="bdshare_t bds_tools get-codes-bdshare">
<a class="bds_qzone"></a>
<a class="bds_tsina"></a>
<a class="bds_tqq"></a>
<a class="bds_renren"></a>
<span class="bds_more">更多</span>
</div>
<script type="text/javascript" id="bdshare_js" data="type=tools&mini=1" ></script>
<script type="text/javascript" id="bdshell_js"></script>
<script type="text/javascript">
/**
* 在这里定义bds_config
*/
var bds_config = {
'bdDes':'您的自定义分享摘要', //'请参考自定义分享摘要'
'bdText':'您的自定义分享内容', //'请参考自定义分享内容'
'bdPopTitle':'您的自定义pop窗口标题', //'请参考自定义pop窗口标题'
'bdTop':'您的自定义侧栏强度', //'请参考自定义侧栏强度'
'bdComment':'您的自定义分享评论', //'请参考自定义分享评论'
'bdPic':'您的自定义分享出去的图片', //'请参考自定义分享出去的图片'
'searchPic':'是有无自动抓取页面图片',//'0为抓取,1为不抓取,默认为0,目前只针对新浪微博'
'wbUid':'您的自定义微博 ID', //'请参考自定义微博 id'
'render':false, //'请参考自定义分享回流量统计'
'review':'normal', //'请参考自定义分享回流签名'
'snsKey':{'tsina':'appkey'} //'请参考自定义分享到平台的appkey'
}
document.getElementById('bdshell_js').src = "http://bdimg.share.baidu.com/static/js/shell_v2.js?cdnversion=" + Math.ceil(new Date()/3500000);
</script>
<!-- Baidu Button END -->

按照官方的土方式,假如有一天在<div>肯能javascript上面定义一下searchPic:0 不就可不可否了吗?

许多,在 修改→清缓存→没效果→修改…几轮苦逼测试后,发现依然无效,分享时还是这么了现 图片!

研究了下点击分享后弹出的网址内容,发现上面的searchPic值死活为false:

当我将地址中的searchPic=false手动改成searchPic=true或searchPic=0时,图片就出来了:

许多,无论是在div里的data中定义searchPic,还是在javascript中定义searchPic,点击分享弹出的地址中,searchPic依然为false!真无语!

折腾了半天没学会英语,正要放弃时,经常 注意到官方代码中的pic可不可否定义自定义图片,于是定义了一张图片地址试了试,发现还真可不可否~!

既然searchPic不好使,那只好先用pic定义个特色图片凑合下咯!

下面说下给百度分享加上特色图片和摘要内容的简单的土方式:

一、在function.php中新增如下函数(有的主题肯能已处在,请自查):

/*特色图片*/
function get_post_thumbnail_url($post_id){
$post_id = ( null === $post_id ) ? get_the_ID() : $post_id;
$thumbnail_id = get_post_thumbnail_id($post->ID);
if($thumbnail_id ){
$thumb = wp_get_attachment_image_src($thumbnail_id, 'thumbnail');
return $thumb[0];
   }else{
return false;
  }
}

二、定义pic图片及text分享内容:

以下土方式二选一即可,代码中的@张戈博客,请自行修改成相应的微博ID,或直接使用博客名称即可:

①、肯能博客用的是仿异次元的百度分享工具条,这么 可不可否如下修改share.php的相应位置代码:

<!--获取文章摘要(新增)-->
<?php
if (!function_exists('utf8Substr')) {
function utf8Substr($str, $from, $len)
{
return preg_replace('#^(?:[\x00-\x7F]|[\xC0-\xFF][\x50-\xBF]+){0,'.$from.'}'.
'((?:[\x00-\x7F]|[\xC0-\xFF][\x50-\xBF]+){0,'.$len.'}).*#s',
'$1',$str);
    }
}
if ( is_single() ){
if ($post->post_excerpt) {
$description = $post->post_excerpt;
     } else {
if(preg_match('/<p>(.*)<\/p>/iU',trim(strip_tags($post->post_content,"<p>")),$result)){
$post_content = $result['1'];
   } else {
$post_content_r = explode("\n",trim(strip_tags($post->post_content)));
$post_content = $post_content_r['0'];
       }
$description = utf8Substr($post_content,0,50);
   }
}
?>
<!--百度分享(修改)-->
<div data="{'url':'<?php the_permalink()?>','pic':'<?php echo get_post_thumbnail_url($post->ID); ?>','text':'分享@张戈博客 的文章「<?php the_title(); ?>」:<?php echo trim($description); ?>...'}" class="bdshare_t bds_tools get-codes-bdshare stb_share_buttons stb_group" id="bdshare">

其中2~24行代码是新增代码,请在share.php中加上即可

第21行中可不可否修改内容字数,代码中默认设置为50个。

第26行是修改后的代码,在share.php中搜索“bdshare_t bds_tools get-codes” 找到位置后,替换整句代码即可

②、通用土方式:找到百度分享代码中的以下javascript:

<script type="text/javascript">
document.getElementById("bdshell_js").src = "http://bdimg.share.baidu.com/static/js/shell_v2.js?cdnversion=" + new Date().getHours();
</script>

替加上以下代码:

<!--获取文章摘要(新增)-->
<?php
if (!function_exists('utf8Substr')) {
   function utf8Substr($str, $from, $len)
   {
     return preg_replace('#^(?:[\x00-\x7F]|[\xC0-\xFF][\x50-\xBF]+){0,'.$from.'}'.
'((?:[\x00-\x7F]|[\xC0-\xFF][\x50-\xBF]+){0,'.$len.'}).*#s',
'$1',$str);
    }
}
if ( is_single() ){
   if ($post->post_excerpt) {
      $description = $post->post_excerpt;
     } else {
     if(preg_match('/<p>(.*)<\/p>/iU',trim(strip_tags($post->post_content,"<p>")),$result)){
      $post_content = $result['1'];
     } else {
      $post_content_r = explode("\n",trim(strip_tags($post->post_content)));
      $post_content = $post_content_r['0'];
       }
$description = utf8Substr($post_content,0,50);
    }
}
?>
<!--百度分享javascript-->
<script type="text/javascript">
var bds_config = {
'bdPic':'<?php echo get_post_thumbnail_url($post->ID); ?>',
'pic':'<?php echo get_post_thumbnail_url($post->ID); ?>',
'text':'分享@张戈博客 的文章「<?php the_title(); ?>」:<?php echo trim($description); ?>...'
}
document.getElementById('bdshell_js').src = "http://share.baidu.com/static/js/shell_v2.js?cdnversion=" + Math.ceil(new Date()/3500000);
</script>

做完以上操作后,你再点击分享,应该就会有图片和内容了:

不过图片这么 一张!稍有遗憾,先凑合使用吧!

后续,张戈本来找到了出理 土方式,会继续分享!敬请关注张戈博客最新动态!