本文首发在我的个人博客:http://cherryblog.site/,欢迎大家前去参观,顺便求fork,么么哒~
上一次在掘金上发表的高阶教程:hexo高阶教程next主题优化之加入网易云音乐、网易云跟帖、动态背景、自定义主题、统计功能,收到了不少朋友的喜欢,手动比心♪(^∀^●)ノ,也有不少朋友私信我给我提改进的意见,本着生命就是要折腾的原则,我又做了如下的优化:
- seo优化
- 多终端修改项目
- 同时托管到github和coding上
- 设置google和百度sitemap,让搜索引擎更好的抓取你的网站
- 使用gulp对css、js进行优化
- 接入七牛图床
- 加入打赏功能
- 加入照片模块
开始做这个博客的时候是想着记录自己学习的过程,并没有指望别人发现(自己比较菜,写的都是一些基础的东西,也没有什么特别nb的技巧值得炫耀〒▽〒),但是自从给博客增加了统计的功能之后,并且在掘金社区发布之后,看着每天还有那么百十号人来看看,内心还有点小激动呢~[]~( ̄▽ ̄)~*
酒香不敌巷子深 我们要做对搜索引擎友好的站点
所以我就在想,怎么才能让其他小伙伴搜索到我写的文章呢?于是就想到了对网站进行seo优化,这段时间也一直在做网站的seo优化,对于hexo生成的博客来说,代码其实修改的并不多,主要是要多用心去给各个搜索引擎提交你的sitemap,让搜索引擎的小蜘蛛多来你的站点,这样别人在搜索东西的时候才有更多的可能搜出你的文章,给你的网站带来人气~
作为一个前端工作者,对网站的优化肯定还是需要有很多的,奈何时间基本都被工作占用,所以就先把优化功能先放了放,只进行了代码压缩
在这半个月的时间,对于hexo搭建搭建的个人博客,虽然没有让我对某一门语言的深度增加,但是却让我对整个建站流程的宽度增加了不少,优化是一件比写出代码的技术难度还要高的事情。
推广是一个烦人的事情啊喂,特别是对于我们搞技术的来说,可能就不擅长推广,那么怎么才能让别人知道我们呢,我们就要想办法让别人通过搜索就可以搜索到你博客的内容,给我们带来自然流量,这就需要seo优化,让我们的站点变得对搜索引擎友好
SEO是由英文Search Engine Optimization缩写而来, 中文意译为“搜索引擎优化”。SEO是指通过站内优化比如网站结构调整、网站内容建设、网站代码优化等以及站外优化。
验证网站所有权
生成网站地图
我们需要使用npm自动生成网站的sitemap,然后将生成的sitemap提交到百度和其他搜索引擎
安装sitemap插件
修改博客配置文件
在根目录配置文件中修改url为你的站点地址
执行完之后就会在网站根目录生成sitemap.xml文件和baidusitemap.xml文件,可以通过http://www.cherryblog.site/baidusitemap.xml,查看该文件是否生成,其中sitemap.xml文件是搜索引擎通用的文件,baidusitemap.xml是百度专用的sitemap文件。
向百度提交链接
然后我们就可以将我们生成的sitemap文件提交给百度,还是在百度站长平台,找到链接提交,这里我们可以看到有两种提交方式,自动提交和手动提交,自动提交又分为主动推送、自动推送和sitemap
如何选择链接提交方式 1、主动推送:最为快速的提交方式,推荐您将站点当天新产出链接立即通过此方式推送给百度,以保证新链接可以及时被百度收录。 2、自动推送:最为便捷的提交方式,请将自动推送的JS代码部署在站点的每一个页面源代码中,部署代码的页面在每次被浏览时,链接会被自动推送给百度。可以与主动推送配合使用。 3、sitemap:您可以定期将网站链接放到sitemap中,然后将sitemap提交给百度。百度会周期性的抓取检查您提交的sitemap,对其中的链接进行处理,但收录速度慢于主动推送。 4、手动提交:一次性提交链接给百度,可以使用此种方式。
一般主动提交比手动提交效果好,这里介绍主动提交的三种方法 从效率上来说:
主动推送>自动推送>sitemap
主动推送
安装插件 然后再根目录的配置文件中新增字段
在加入新的deploye
这样执行的时候,新的链接就会被推送了
设置自动推送
在主题配置文件下设置,将baidu_push设置为true:
然后就会将一下代码自动推送到百度,位置是themes extlayout_scriptsbaidu_push.swig,这样每次访问博客中的页面就会自动向百度提交sitemap
sitemap
除了百度和google两大搜索引擎,还有搜狗、360等其他的搜索引擎,流程都是一样的 ,大家就自行选择添加哈,这里就不再赘述了~
seo搜索引擎优化认为,网站的最佳结构是用户从首页点击三次就可以到达任何一个页面,但是我们使用hexo编译的站点打开文章的url是:sitename/year/mounth/day/title四层的结构,这样的url结构很不利于seo,爬虫就会经常爬不到我们的文章,于是,我们可以将url直接改成sitename/title的形式,并且title最好是用英文,在根目录的配置文件下修改permalink如下:
seo优化应该说是一个收益延迟的行为,可能你做的优化短期内看不到什么效果,但是一定要坚持,seo优化也是有很深的可以研究的东西,从我们最初的网站设计,和最基础的标签的选择都有很大的关系,网站设计就如我们刚刚说的,要让用户点击三次可以到达网站的任何一个页面,要增加高质量的外链,增加相关推荐(比如说我们经常见到右侧本站的最高阅读的排名列表),然后就是给每一个页面加上keyword和描述 在代码中,我们应该写出能让浏览器识别的语义化HTML,这样有助于爬虫抓取更多的有效信息:爬虫依赖于标签来确定上下文和各个关键字的权重;并且对外链设置nofollow标签,避免spider爬着爬着就爬出去了(减少网站的跳出率),并且我们要尽量在一些比较大的网站增加我们站点的曝光率,因为spider会经常访问大站,比如我们在掘金等技术社区发表文章中带有我们的站点,这样spider是很有可能爬到我们中的站点的,so…. - 网站外链的推广度、数量和质量 - 网站的内链足够强大 - 网站的原创质量 - 网站的年龄时间 - 网站的更新频率(更新次数越多越好) - 网站的服务器 - 网站的流量:流量越高网站的权重越高 - 网站的关键词排名:关键词排名越靠前,网站的权重越高 - 网站的收录数量:网站百度收录数量越多,网站百度权重越高 - 网站的浏览量及深度:用户体验越好,网站的百度权重越高
前面已经提到过一个惨绝人寰的消息,那就是github是不允许百度的爬虫爬取内容的,所以我们的项目如果是托管在github上的话基本是不会被百度收录的,所以我又同时托管到了coding上,然后在做解析的时候海外的ip 指向到github,国内的或者说百度的直接指向coding
Coding 是一个面向开发者的云端开发平台[1] ,目前提供代码托管,运行空间,质量控制,项目管理等功能。此外,还提供社会化协作功能,包含了社交元素,方便开发者进行技术讨论和协作。 2016年3月CODING宣布收购代码托管平台GitCafe。
之前好多小伙伴都是将项目托管在gitcafe上,但是现在gitcafe被coding收购了,于是就转到coding上了,之前好多人说github的服务器在国外,于是就转战国内的coding了,我将代码迁移至coding还有另外一个原因,github不让百度的爬虫爬取啊,让我哭一会,不然也不会这样折腾。coding就是中国版的github(只是打一个比喻),有提供pages服务。
在coding上创建仓库
将hexo博客同步到新创建的仓库中
所以我的配置就是这样的(我这个配置github和coding都有ssh和https两种方式):
完成之后在git bash 中输入
设置coding的pages服务
设置域名解析
至此就完成了将你的hexo编译的博客同时部署在github和coding上
之前就想到了一个问题,如果我想要在公司写博客怎么办,或者说如果我换电脑了怎么办,因为在github中的我们github.io项目是只有编译后的文件的,没有源文件的,也就是说,如果我们的电脑坏了,打不开了,我们的博客就不能进行更新了,所以我们要把我们的源文件也上传到github上,这道题的解题思路(哈哈,突然想到这个词了)是,将我们的源文件上传至username.github.io的Hexo分支,并且设置为默认分支(分支需要自己创建),然后对我们的源文件进行版本管理,这样我们就可以在另一台电脑上pull我们的源码,然后编译完之后push上去。
更为优雅的方式是使用travis-ci,然后用webhook自动部署。你只需要写markdown,push到github就行了。根本不用关心deploy,只要维护你的markdown就行。详情请参考:http://blog.bigruan.com/2015-03-09-Continuous-Integration-Your-Hexo-Blog-With-TravisCI/
创建两个分支:master 与 Hexo,并将Hexo设置为默认分支(这个Hexo分支就是存放我们源文件的分支,我们只需要更新Hexo分支上的内容据就好,master上的分支hexo编译的时候会更新的)
因为有些主题是从git上clone过来的,所以我们要先删除.git缓存文件,否则会和blog仓库冲突(.git默认是隐藏文件夹,需要先开启显示隐藏文件夹。.git文件夹被删除后整个文件对应的git仓库状态也会被清空) .gitignore文件作用是声明不被git记录的文件,blog根目录下的.gitignore是hexo初始化带来的,可以先删除或者直接编辑,对hexo不会有影响。建议.gitignore内添加以下内容:
.deploy_git是hexo默认的.git配置文件夹,不需要同步 public内文件是根据source文件夹内容自动生成,不需要备份,不然每次改动内容太多 即使是私有仓库,除去在线服务商员工可以看到的风险外,还有云服务商被攻击造成泄漏等可能,所以不建议将配置文件传上去
然后我们再初始化仓库,重新对我们的代码进行版本控制
是指在线仓库的地址。origin是本地分支,remote add操作会将本地仓库映射到云端
依次执行
提交网站相关的文件;
假设B电脑现在没有我们的源文件
平时我们对源文件有修改的时候记得先pull一遍代码,再将代码push到Hexo分支,就和日常的使用git一样~ 1. 依次执行git add .、git commit -m “…”、git push origin Hexo指令将改动推送到GitHub(此时当前分支应为Hexo); 2. 然后才执行hexo g -d发布网站到master分支上。
当你在你的博客页面右键查看源代码的时候,你会发现你的html页面中会有大段大段的空白,这个时候我们就要使用压缩工具对我们的代码进行压缩,在前一段时间参见的前端开发者大会(FDCon2017)中,携程的框架式就有讲到,在携程,线上的资源是需要申请的(单位具体到k),所以说我们的代码不压缩实在是太奢侈~
在2017年的前端中,gulp似乎不是最流行的自动化工具,但是谁让我们公司用的是gulp呢。为了能和公司用一样的构建工具,所以我自己的博客也是使用的gulp。 gulp是前端开发过程中对代码进行构建的工具,是自动化项目的构建利器。不仅能对网站的资源进行优化,并且能在开发过程中能够对很多重复的任务使其自动完成。
能自动化地完成 javascript/coffee/sass/less/html/image/css 等文件的的测试、检查、合并、压缩、格式化、浏览器自动刷新、部署文件生成,并监听文件在改动后重复指定的这些步骤。在实现上,她借鉴了Unix操作系统的管道(pipe)思想,前一级的输出,直接变成后一级的输入,使得在操作上非常简单。
既然gulp是基于node,所以我们就要先有node环境,不过我们本身就是使用hexo构建我们的博客,就已经是基于node环境了~
npm小知识
npm(node package manager)nodejs的包管理器,用于node插件管理(包括安装、卸载、管理依赖等)
使用npm安装插件:
- :node 插件名称
- :全局安装,会在node安装的根目录下载对应的包,在计算机的任何文件都可以使用该插件,默认的node安装目录是:;如果不带该属性,将会安装在当前目录,下载安装包的位置是当前目录的文件夹
- :将配置信息保存在node项目配置文件中
- :保存至 的devDependencies节点,如果没有该属性,该插件将会被保存至dependencies节点,devDependencies和dependencies有什么区别呢?其实从名字就应该可以看出来两者的区别,devDependencies中dev是development(开发)的缩写,dependencies是依赖的意思。所以 dependencies 是程序正常运行所需要安装的依赖,而devDependencies是开发所需要的依赖,比如一些单元测试的包~
- 为什么要保存至package.json?因为我们使用node的时候需要很多的包,所以我们将我们的配置信息,也就是我们需要包的名称等其他信息保存至一个文件中,如果说其他开发者就可以直接使用一个命令就可以安装和我们相同的配置,这个命令就是,就可以下载 下所有需要的包。则只下载dependencies下的包
使用npm卸载插件:
- 在npm中要卸载插件不是将文件夹删除就可以了,因为你的配置信息还在package中,所以要使用 命令
- 删除全部插件:(首先你需要先安装rimraf 插件)
更新npm插件:
使用cnpm
什么是cnpm呢,大家都知道,由于不可描述原因,我们访问国外的资源有时候的速度,大家懂的,所以淘宝除了一个npm镜像,服务器就在中国。c可以理解为China(应该可以这样理解吧),cnpm使用方法和npm完全相同,只需将npm全部换成cnpm就可以。本文都是使用的npm,如果想要尝试cnpmde的麻烦自行替换~
这是一个完整 npmjs.org 镜像,你可以用此代替官方版本(只读),同步频率目前为 10分钟 一次以保证尽量与官方服务同步。
cnpm 官网地址:http://npm.taobao.org; 安装命令为
注意:安装完后最好查看其版本号或关闭命令提示符重新打开,安装完直接使用有可能会出现错误;
言归正传,简单介绍了gulp和npm,我们需要的是使用gulp压缩我们的代码 ,然后 查看版本号就可以知道我们是不是安装成功了~*★,°:.☆( ̄▽ ̄)/$:.°★*。撒花!
在你的Hexo目录下右键然后执行,和gulp有关的包名称有以下几个,只需将替换一下就好~
聪明的你是不是觉得有些眼熟,对的,就是我po出来的package.json中下面对应的包名称和版本号~是不是和刚刚所讲的npm的知识联系到了一块呢~
gulp.js是gulp的配置文件,需要我们手动创建(应该还会有更高级的方法T T ) 我的gulp.js文件如下
在git bash中执行
在git bash中直接输入命令就可以,这个是你自己创建的任务,你创建的任务是什么名的就在gulp后面跟什么名字
在webstorm中执行
增加七牛图床就是要将我们电脑上的图片上传至七牛,然后获得外链,在我们使用md写博客的时候直接插入外链,更方便的是可以直接获取带水印、压缩、剪裁过后的图片~
万年不变的第一步,注册。官网:七牛云