基于Node.js搭建hexo博客的示例
小编给大家分享一下基于Node.js搭建hexo博客的示例,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
创新互联建站专注于企业成都全网营销推广、网站重做改版、通榆网站定制设计、自适应品牌网站建设、H5响应式网站、商城开发、集团公司官网建设、成都外贸网站建设、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为通榆等各大城市提供网站开发制作服务。
一、安装新版本的nodejs和npm
安装n模块:
npm install -g n
升级node.js到最新稳定版
n stable
二、安装hexo
note: 参考github,不要去其官网
安装Hexo
npm install hexo-cli -g
Setup your blog
hexo init blemesh
cd blemesh
安装Cactus主题,众多开源主题中比较简洁的一个:
主题页
Cactus页
git clone https://github.com/probberechts/hexo-theme-cactus.git themes/cactus
修改主题配置:
vim _config.yml
# Extensions
## Plugins: https://hexo.io/plugins/
## Themes: https://hexo.io/themes/
## theme: landscape
theme: cactus
theme_config:
colorscheme: white
Create pages and articles with the hexo new [layout]
command. For example, to create an "about me" page, run:</p><pre>hexo new page about</pre><p>This will create a new file in source/about/index.md Similary, you can create a new article with</p><pre>hexo new post "hello world"</pre><p>and add some interesting content in source/_posts/hello-world.md.</p><p>Start the server:</p><pre>hexo server</pre><p>8001 port:</p><pre>hexo server -p 8001</pre><p><strong>三、安装hexo-admin并配置</strong></p><p>安装:</p><pre>npm install --save hexo-admin</pre><p>打开目录下的_config.yml配置hexo-admin:</p><p>admin:</p><pre>username: XXXX(自己设置用户名)
password_hash: XXXXXXXXX(密码,但是是明文经过bcrypt hash加密后生成的)
secret: hey hexo(用于cookie安全)
deployCommand: './admin_script/hexo-generate.sh'(调用该脚本)</pre><p>注:</p><p>1)其中password_hash是你自己的明文密码经过加密后的字符串,但是如果用类似下面的网址: https://bcrypt-generator.com/ 会生成:$2y$10$pJjIxxxxxfMn9U/xxxxxNuuA20kh2eoB7vZxxxxx/7WpeV7IOxxxx类似的加密串,但是运行会报invalid salt revision错误,其原因是:</p><pre>➜ blemesh cat node_modules/hexo-admin/www/bundle.js | head -4851 | tail -10
if (salt.charAt(0) != '$' || salt.charAt(1) != '2')
throw "Invalid salt version";
if (salt.charAt(2) == '$')
off = 3;
else {
minor = salt.charAt(2);
if (minor != 'a' || salt.charAt(3) != '$')
throw "Invalid salt revision";
off = 4;
}</pre><p>需要版本号是2a的加密方式,因此只能用python自己写了:</p><p>https://pypi.org/project/bcrypt/3.1.0/</p><pre>>>> hashed = bcrypt.hashpw(password, bcrypt.gensalt(prefix=b"2a"))
>>> print(hashed)
b'$2a$12$PAoJr3USOBxxxxxxxxxxxxxxV/.h.QNbh/6q.xxxxxxxxxxxxxxxxcDcJ.'</pre><p>2)其中配置中有个脚本: ./admin_script/hexo-generate.sh 需要自己创建:</p><pre>➜ blemesh cat admin_script/hexo-generate.sh
hexo g
➜ blemesh chmod +x admin_script/hexo-generate.sh</pre><p>这个脚本有什么用,啥时候触发?可以参考: https://www.jianshu.com/p/68e727dda16d step 5,admin后台管理博客有个deploy按钮,点击这个按钮就会执行这个脚本,该脚本会将md文件生成静态网页,如果用nginx配置去访问静态网页,速度会快很多。</p><p><strong>四、nginx配置</strong></p><p>配置nginx:编辑 /etc/nginx/nginx.conf 插入下面代码:</p><pre>server {
listen 3001;
server_name www.beautifulzzzz.com;
index index.html index.htm index;
root /root/App/blemesh/public;
}</pre><p>之后重启nginx:nginx -s reload</p><p>注:<br/>执行nginx后会报错误:nginx 403 Forbidden,原因是配置文件nginx.conf文件的执行用户和当前用户不一致导致的,把之前的nobody改成当前用户root。</p><p><strong>五、增加tag</strong></p><p>hexo主页下的tag标签、category标签无显示找不到:</p><p>解决办法: 在主目录下执行 hexo new page "tags"或者hexo new page "category"<br/>在/source/tags/index.md中设置修改</p><pre>➜ blemesh cat ./source/tags/index.md
---
type: "tags"
comments: false
date: 2019-02-24 02:53:03
---</pre><p>同理categories:</p><pre>➜ blemesh cat ./source/category/index.md
---
type: "category"
comments: false
date: 2019-02-24 02:53:34
---</pre><p>或者about me:</p><pre>➜ blemesh cat ./source/about/index.md
---
title: about
type: "about-me"
comments: false
date: 2019-02-22 00:09:58
---</pre><p><strong>六、后台启动</strong></p><p>hexo server进程一直在后台运行的办法(执行hexo server -d &在一段时间后会停止hexo,此时无法打开后台),采用pm2接管hexo进程:</p><pre>npm install -g pm2</pre><p>在博客的根目录下创建一个hexo_run.js的文件,文件内容如下:</p><pre>➜ blemesh cat hexo_run.js
const { exec } = require('child_process')
exec('hexo server -p 8001 -d',(error, stdout, stderr) => {
if(error){
console.log('exec error: ${error}')
return
}
console.log('stdout: ${stdout}');
console.log('stderr: ${stderr}');
})</pre><p>运行开启命令: pm2 start hexo_run.js</p><p>最后附上 zhouwaiqiang 写的一个hexo重启脚本restart_hexo.sh(需要先配置好nginx),需要重启刷新的时候执行source restart_hexo.sh即可:</p><pre>➜ blemesh cat restart_hexo.sh
#!/bin/bash
PROCESS=`ps -ef|grep hexo|grep -v grep|grep -v PPID|awk '{ print $2 }'`
PROC_NAME="pm2"
for i in $PROCESS
do
echo "Kill the $1 process [ $i ]"
kill -9 $i
done
hexo clean #清除数据
hexo generate #生成静态文件public文件夹
ProcNumber=`ps -ef |grep -w $PROC_NAME|grep -v grep|wc -l`
if [ $ProcNumber -le 0 ];then
pm2 start hexo_run.js
else
pm2 restart hexo_run.js
fi
service nginx restart</pre><p><strong>七、体验</strong></p><ul><li><p>启动:sh ./restart_hexo.sh</p></li><li><p>访问主页: http://www.beautifulzzzz.com:8001/</p></li><li><p>访问nginx静态快速版网页: http://www.beautifulzzzz.com:3001/</p></li><li><p>访问后台编写文章: http://www.beautifulzzzz.com:8001/admin/</p></li><li><p>编写好之后点击Deploy会自动调用之前的脚本,静态网页就有了</p></li></ul><p><img src="/upload/otherpic51/19698.png" alt="基于Node.js搭建hexo博客的示例"></p><p>以上是“基于Node.js搭建hexo博客的示例”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!</p>
<br>
网站题目:基于Node.js搭建hexo博客的示例 <br>
文章链接:<a href="http://ndjierui.cn/article/gsogcp.html">http://ndjierui.cn/article/gsogcp.html</a>
</div>
<div class="view-qrocde cl">
<div class="m z"><img src="/Public/Home/images/ew.jpg"/></div>
<div class="text">
<h6>扫二维码与项目经理沟通</h6>
<p>我们在微信上24小时期待你的声音</p>
<p>解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流</p>
</div>
</div>
<div class="othernews cl">
<h3>其他资讯</h3>
<ul>
<li><a href="/article/descoog.html">sap系统上线有哪些问题的简单介绍</a></li><li><a href="/article/descocd.html">sap系统与预算的简单介绍</a></li><li><a href="/article/descodi.html">sap系统里面批准标示z的简单介绍</a></li><li><a href="/article/desdhhj.html">linux的命令汇总 linux中各种命令</a></li><li><a href="/article/descoci.html">包含蒙牛sap系统怎么使用的词条</a></li> </ul>
</div>
</div>
</div>
<div class="sidebar">
<div class="tuijian">
<a href="#">
<h2 class="cl"><span>行业动态</span></h2>
<h3>企业网站建设的重要性!</h3>
<p>现在虽然是移动互联网时代,但企业网站依然重要,包含PC站点,移动站。可以说企业网站关系企业的未来发展和前途,尤其对中小企业更是如此,一些中小企业老板,对自己的名片很在乎,因为这是个门面。...</p>
</a>
</div>
<div class="ser sidesub">
<h2>服务项目</h2>
<ul class="ebox">
<li class="sub sub-1">
<div>
<h3>网站建设</h3>
<p></p>
<a class="btn" href="/serve/website/">查看详情</a>
</div>
</li>
<li class="sub sub-1">
<div>
<h3>移动端/APP</h3>
<p></p>
<a class="btn" href="/serve/moblie/">查看详情</a>
</div>
</li>
<li class="sub sub-1">
<div>
<h3>微信/小程序</h3>
<p></p>
<a class="btn" href="/serve/small/">查看详情</a>
</div>
</li>
<li class="sub sub-1">
<div>
<h3>技术支持</h3>
<p></p>
<a class="btn" href="/serve/tech/">查看详情</a>
</div>
</li>
<li class="sub sub-1">
<div>
<h3>其它服务</h3>
<p></p>
<a class="btn" href="/serve/othe/">查看详情</a>
</div>
</li>
<li class="sub sub-5">
<div>
<h3>更多服务项目</h3>
<p> <a>用我们的专业和诚信赢得您的信赖,从PC到移动互联网均有您想要的服务!</a></p>
<a class="btn" href="/serve/">获取更多</a>
</div>
</li>
</ul>
</div>
<div class="contact" id="fix">
<h2 class="cl"> <span>联系吧</span> <a href="https://map.baidu.com/" class="ditu" rel="nofollow" target="_blank">在百度地图上找到我们</a> </h2>
<h3>电话:13518219792</h3>
<p>如遇占线或暂未接听请拨:136xxx98888</p>
<div class="qq"> <a href="//wpa.qq.com/msgrd?v=3&uin=244261566&site=qq&menu=yes" rel="nofollow" target="_blank">业务咨询</a> <a href="//wpa.qq.com/msgrd?v=3&uin=244261566&site=qq&menu=yes" rel="nofollow" target="_blank">技术咨询</a> <a href="//wpa.qq.com/msgrd?v=3&uin=244261566&site=qq&menu=yes" rel="nofollow" target="_blank">售后服务</a> </div>
</div>
</div>
<script>
//固定滚动
(function () {
var oDiv = document.getElementById("fix");
var H = 120,
iE6;
var Y = oDiv;
while (Y) {
H += Y.offsetTop;
Y = Y.offsetParent
};
iE6 = window.ActiveXObject && !window.XMLHttpRequest;
if (!iE6) {
window.onscroll = function ()
{
var s = document.body.scrollTop || document.documentElement.scrollTop;
if (s > H) {
oDiv.className = "contact fixed";
if (iE6) {
oDiv.style.top = (s - H) + "px";
}
} else {
oDiv.className = "contact ";
}
};
}
})();
</script>
</div>
<div class="footer">
<div class="wp">
<div class="wpss cl">
<dl class="about">
<dt>网站设计</dt>
<dd><a href="https://www.cdcxhl.com/xiangyingshi.html" target="_blank" title="响应式网站设计">响应式网站设计</a></dd><dd><a href="http://www.kswcd.cn/" target="_blank" title="成都网站设计">成都网站设计</a></dd><dd><a href="http://www.4006tel.net/vision/website.html" target="_blank" title="网站设计">网站设计</a></dd><dd><a href="http://chengdu.cdcxhl.com/" target="_blank" title="成都网站设计">成都网站设计</a></dd> </dl>
<dl class="about">
<dt>网站制作</dt>
<dd><a href="http://www.cxjianzhan.com/" target="_blank" title="网站制作公司">网站制作公司</a></dd><dd><a href="http://www.cxjianzhan.com/" target="_blank" title="成都网站制作">成都网站制作</a></dd><dd><a href="http://www.36103.cn/" target="_blank" title="成都网站制作">成都网站制作</a></dd><dd><a href="http://www.kswcd.com/mobile/" target="_blank" title="手机网站制作">手机网站制作</a></dd> </dl>
<dl class="contact">
<dt>联系我们</dt>
<dd>电话:13518219792</dd>
<dd>邮箱:631063699@qq.com</dd>
<dd>地址:成都青羊区锦天国际1002号</dd>
<dd>网址:www.ndjierui.cn</dd>
</dl>
<dl class="about" style="margin-left:50px;width:235px;">
<dt>网站建设</dt>
<dd><a href="http://www.cqcxhl.com/" target="_blank" title="重庆企业网站建设">重庆企业网站建设</a></dd><dd><a href="http://www.kswcd.com/solution/" target="_blank" title="网站建设方案">网站建设方案</a></dd><dd><a href="http://chengdu.cdcxhl.com/" target="_blank" title="营销型网站建设">营销型网站建设</a></dd><dd><a href="http://www.cdkjz.cn/fangan/" target="_blank" title="网站建设方案">网站建设方案</a></dd> </dl>
<dl class="flow">
<dt></dt>
<div class="ma cl">
<div class="m"> <img src="/Public/Home/images/ew.jpg" />
<p>微信二维码</p>
</div>
</div>
</dl>
</div>
</div>
<div class="footer-link wp">
<ul class="wpss cl">
<li class="fisrt">友情链接</li>
<li><a href="http://www.csruijie.cn/" title="csruijie.cn" target="_blank">csruijie.cn</a></li><li><a href="http://www.szsmxy.cn/" title="成都圣月服饰" target="_blank">成都圣月服饰</a></li><li><a href="http://chengdu.kswsj.cn/" title="高端网站设计" target="_blank">高端网站设计</a></li><li><a href="http://www.idckuai.cn/" title="网站空间" target="_blank">网站空间</a></li><li><a href="http://www.cdxwcx.cn/tuoguan/nanchong.html" title="南充主机托管" target="_blank">南充主机托管</a></li><li><a href="http://www.jyruizhi.cn/" title="无纺布袋定制" target="_blank">无纺布袋定制</a></li><li><a href="http://m.cdcxhl.cn/dingzhi/
" title="高端定制网站建设" target="_blank">高端定制网站建设</a></li><li><a href="http://www.ghjinhua.cn/" title="广汉锦华橡塑" target="_blank">广汉锦华橡塑</a></li><li><a href="http://www.cdhuace.com/zhuangxiu.html" title="成都装饰装修" target="_blank">成都装饰装修</a></li><li><a href="https://www.91wanzhong.com/" title="成都抖音代运营" target="_blank">成都抖音代运营</a></li> </ul>
</div>
</div>
<div class="bot-footer">
<div class="wp">
<p class="wpss"> <em>Copyright © 2002-2025 www.ndjierui.cn 广皓图文建站品牌 QQ:244261566 版权所有</em> <em>备案号:<a href="http://beian.miit.gov.cn/" rel="external nofollow">蜀ICP备2025118593号-2</a></em>
</p>
<p class="wpss" style="line-height:30px !important;"> </p>
</div>
</div>
<div class="footer-kefu">
<ul>
<li class="qq"><a href="https://wpa.qq.com/msgrd?v=3&uin=244261566&site=qq&menu=yes"><em></em>在线咨询</a>
</li>
<li class="tel"><a href="tel:13518219792" target="_blank"><em></em>13518219792</a></li>
<li class="wx"> <em></em>
<div class="code"> <img src="/Public/Home/images/ew.jpg" />
<p>微信二维码</p>
</div>
</li>
<li class="m"> <em></em>
<div class="code"> <img src="/Public/Home/images/ew.jpg" />
<p>移动版官网</p>
</div>
</li>
<li class="top"><em></em></li>
</ul>
</div>
<script src="/Public/Home/js/all.js"></script>
</body>
</html>
<script>
$(".cont img").each(function(){
var src = $(this).attr("src"); //获取图片地址
var str=new RegExp("http");
var result=str.test(src);
if(result==false){
var url = "https://www.cdcxhl.com"+src; //绝对路径
$(this).attr("src",url);
}
});
window.onload=function(){
document.oncontextmenu=function(){
return false;
}
}
</script>