美文网首页自由世界hexo优化配置Hexo 博客
Hexo博客收录百度和谷歌-基于Next主题

Hexo博客收录百度和谷歌-基于Next主题

作者: 小矮人Ethan | 来源:发表于2016-12-19 12:28 被阅读4463次

    Hexo博客收录百度和谷歌-基于Next主题(应该是比较全面的一篇教程)

    我们的博客做出来当然是希望别人来访问,但是Github和Coding都做了防爬虫处理,这样子我们博客可能就无法被搜索引擎收录,需要我们手动提交!

    本教程基于Hexo博客框架,使用Next主题(其他主题举一反三),博主本人已绑定自己的域名(在下文会点明区别,没有太大影响);很多过程使用了Flow.ci进行自动构建!

    原创文章,转载请注明出处

    你需要准备的

    1.百度站长账号;

    没有的申请,很简单,跟百度分析一起使用挺好,不过分析的话还是推荐CNZZ,不过都挂上没有坏处!

    2.谷歌账号:

    谷歌账号能够享受所有的谷歌服务,当然也包括网站搜索分析服务!不过需要提前准备梯子!

    3.Flow.ci用于自动构建网站地图(推荐,非必须):

    可参考这篇文章>>配置自动构建,本文会在这基础之上进行提高!

    4.最重要的是你有自己的博客!

    验证你的站点是否被收录:

    一般情况下你的站点是不能被搜到的!你可以用site验证:

    验证百度:

    site:www.oneonecity.xyz域名换成你自己的,百度还支持site搜索么?如果没有找到你的博客说明没有被收录!

    验证谷歌:

    site:www.oneonecity.xyz域名换成你自己的,谷歌是一定支持的,不过你需要梯子!如果没有找到你的博客说明没有被收录!

    收录百度

    措辞是不是有问题?就是你的网站被百度搜索收录!

    1.手动提交:

    你可以手动提交你的站点到百度搜索,点这里>>,当然这种方法很麻烦,因为如果想让每一篇文章都能被搜索到就需要把所有的页面链接进行提交!

    2.验证网站所有权:

    通过验证之后百度会认为你是网站所有者,然后能做诸如自动推送、手动推送的高级功能!
    点这里>>,输入你的博客首页地址(可以是自己的域名也可以是Coding或者Github的Pages页面地址!),然后点击下一步!

    3.进行验证:

    这里有三种方法:文件验证、HTML标签验证和CNAME验证。下面分别说一下方法和适用范围!

    (1)文件验证:

    百度文件验证
    a.你需要做的是下载验证文件:是一个html文件,里面存放着你的token信息!
    b.然后将这个文件放在你的主题的根目录下,之所以不放在source是因为Next主题在构建过程中会在验证文件中加入很多东西影响验证!
    c.接下来就是编译部署你的博客hexo g -d,如果你已经实现自动化部署的话只需要push你的原文件:
    git add .
    
    git commit -am "添加验证文件"
    
    git push origin master
    

    关于自动部署,请移步这里>>
    d.点击点击这里进行验证,其实是你的博客首页加了验证文件路径;
    e.最后点击完成验证如果顺利的话,是能够完成!这种方法比较麻烦,不是很推荐!

    (2)HTML标签验证:

    这种方法需要根据不同的主题进行配置,博主使用的Next主题,其他主题可以自己摸索,原理一样:都是将HTML验证标签加入到博客每个页面的head里面!注意是红框中完整的标签,而不是一部分!

    百度文件验证
    第一步:将该标签(红框中完整的,并非只是后面的token)
    第二步:在Next主题配置文件(不是博客配置文件)开启提交百度的选项:
    百度文件验证
    # 此处设置成true之后,将themes/next/layout/_partials/head.swig 
    # 下把默认的百度和 google 验证值替换为搜索引擎为你提供的完整HTML标签即可
    google_site_verification: true
    baidu_site_verification: true
    

    这里的名字google_site_verification:可以随便起,不过需要与后面的themes/next/layout/_partials/head.swig中相对应,默认都是下划线!
    第三步:修改themes/next/layout/_partials/head.swig,添加从百度获取的完整的HTML验证标签,注意名字的对应!

    {% if theme.baidu_site_verification %}
      <meta name="baidu-site-verification" content="yourtoken" />
    {% endif %}
    

    第四步:同文件验证的c.步骤:编译部署你的博客!进入你的博客首页或者任意文章,按F12,如果再head标签中看到了验证标签,就可以了!

    百度文件验证
    第五步:点击验证按钮!,如果过程没问题则会验证成功!

    (3)CNAME验证,如果你绑定了自己的域名,这种方式是最简单的!

    第一步:你要有自己的域名并使用CNAME解析,如果没有请移步这里>>
    第二步:如图添加一条新的CNAME解析:记录类型CNAME主机记录是你的token,,记录值是zz.baidu.com,其他默认:

    百度文件验证
    第三步:点击验证!这一种方法最简单,推荐!

    收录谷歌:

    HTML 标签验证,参考百度验证!

    {% if theme.google_site_verification %}
      <meta name="google-site-verification" content="yourtoken" />
    {% endif %}
    

    生成站点地图:

    这一步很重要,通过构建网站地图能够让搜索引擎更好的抓取你的网站内容!

    1.安装sitmap插件:

    npm install hexo-generator-sitemap --save
    npm install hexo-generator-baidu-sitemap --save
    

    如果你搭建了基于Flow.ci的自动构建,请修改Flow.ci的自定义脚本:

    # 安装Hexo命令行工具
    flow_cmd "npm install hexo-cli -g" --echo
    flow_cmd "npm install hexo-generator-sitemap --save" --echo
    flow_cmd "npm install hexo-generator-baidu-sitemap --save" --echo
    
    # 准备并安装私钥
    flow_cmd "cp .ssh/id_rsa ." --echo
    flow_cmd "chmod 600 ./id_rsa" --echo
    flow_cmd "eval $(ssh-agent)" --echo
    flow_cmd "ssh-add ./id_rsa" --echo
    
    # 执行Hexo生成和发布
    
    flow_cmd "hexo clean" --echo
    flow_cmd "hexo g" --echo
    flow_cmd "hexo d" --echo
    flow_result $?
    

    2.修改博客配置文件:

    a.修改URL为你博客首页,这样是为了保证生成的sitemap.xml文件中地址正确:


    百度文件验证

    b.指定生成文件名及路径,在配置文件最后添加一下代码:

    # 自动生成sitemap
    sitemap: 
      path: sitemap.xml
    baidusitemap: 
      path: baidusitemap.xml
    

    c.执行构建hexo g,正常情况下会在source文件夹下看到多出两个文件:sitemap.xmlbaidusitemap.xml,这就是sitemap文件。
    此后等待搜索引擎抓取或者配置自动推送或者主动推送!

    自动推送sitemap到百度:

    基于Next主题,其他主题原理一样:

    修改主题配置文件

    baidu_push状态改成true

    # Enable baidu push so that the blog will push the url to baidu automatically which is very helpful for SEO
    baidu_push: true
    

    修改baidu_push.swig:

    位置是themes\next\layout\_scripts\baidu_push.swig,添加以下代码(代码来自百度自动推送)

    {% if theme.baidu_push %}
    <script>
    (function(){
        var bp = document.createElement('script');
        var curProtocol = window.location.protocol.split(':')[0];
        if (curProtocol === 'https') {
            bp.src = 'https://zz.bdstatic.com/linksubmit/push.js';        
        }
        else {
            bp.src = 'http://push.zhanzhang.baidu.com/push.js';
        }
        var s = document.getElementsByTagName("script")[0];
        s.parentNode.insertBefore(bp, s);
    })();
    </script>
    {% endif %}
    

    这样子的话每次访问博客中的页面会自动向百度提交。

    提交Google站点地图:

    添加/测试站点地图

    点此>>进入Google Search Console控制台,需要翻墙。
    点击你的站点,如果没有请先添加站点;
    然后点击控制台-->抓取-->站点地图,点击右上角添加/测试站点地图按钮,将你的sitemap.xml提交测试,测试成功之后重复该步骤进行添加!

    谷歌sitemap
    帮助文档>>

    主动推送到百度:

    该过程配合Flow.ci实现起来很方便,单独开篇,点此跳转>>
    任何问题,欢迎讨论!

    相关文章

      网友评论

      • abd42bce169a:一直验证CNAME失败咋回事阿:sob: ,主机的域名解析成功了
      • e6a56e3205c8:平时用谷歌系平台google plus,表示外贸出口营销毫无压力。
      • 04f6412dddc7:大哥,我的没有生成sitemap.xml 文件
        小矮人Ethan:需要先安装生成sitemap的插件
      • Winter_Chen:很实用
      • 4e990ec1b71e:您好 我显示抓取失败 在百度上提交sitemap的时候
        HarlanZhou:@小矮人Ethan 我也是自动提交,始终无法被收录
        HarlanZhou:我也是百度抓取失败,请问这位朋友你解决了么?我的博客还是无法被百度收录
        小矮人Ethan:@只是太任性 手动提交的还是自动提交的?
      • 4e990ec1b71e:您好我按照步骤来 但是最后没有baidu_push.swig这个文件,麻烦您能帮我一下吗?
        小矮人Ethan:@只是太任性 理论上是可以的,创建之后还要在主题的配置文件里相应的增加这个配置项开关
        萝莉武侠社:@小矮人Ethan 我的也没有baidu_push.swig这个文件,自己创建了一个,不知道行不行?
        小矮人Ethan:@只是太任性 这个文件是主题自带的。
      • 585415e4d5b8:我的html验证失败,看了一下html发现<meta>标签没有“/”所以不识别,请问你们html可以验证成功吗?
        小矮人Ethan:@Outsider_2cb5 后面的尖括号里面是要有斜杠的
      • 海大化州同乡会:说一下我的步骤,博主帮我看看是否正确呢?
        我用了CNAME验证成功后,在百度站长平台可以看到自己的的域名。
        然后我在主题配置文件将baidu_push状态改成true;
        然后手动添加并且修改baidu_push.swig这个文件,
        然后我在hexo主文件夹下git命令“hexo g -d”。
        以上是我的全部操作。请问这样就可以了吗?
        小矮人Ethan:@海大化州同乡会 安装sitemap 那一章节
        海大化州同乡会:怎么样子手动更新呢?
        小矮人Ethan:@海大化州同乡会 百度验证通过之后当你部署一次会提交sitemap的,但是如果你添加新的文章你需要手动更新sitemap 。

      本文标题:Hexo博客收录百度和谷歌-基于Next主题

      本文链接:https://www.haomeiwen.com/subject/uihtvttx.html