成都创新互联网站制作重庆分公司

基于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://cxhlcq.com/article/gsogcp.html">http://cxhlcq.com/article/gsogcp.html</a> </div> </div> </div> <div class="other container"> <h3>其他资讯</h3> <ul> <li> <a href="/article/ddpjoec.html">包含阿里云服务器ecs预装系统的词条</a> </li><li> <a href="/article/ddpjogs.html">c语言子函数实现整数求和 c语言求整数之和</a> </li><li> <a href="/article/ddpjoeh.html">帝国cms的文档 帝国cms栏目没有了</a> </li><li> <a href="/article/ddpjogj.html">关于sap系统销售口令的信息</a> </li><li> <a href="/article/ddpjoip.html">取消java代码注释 java取消注释的快捷键</a> </li> </ul> </div> <div class="footer"> <div class="foota container"> <div class="foot_nav fl col-lg-8 col-md-8 col-sm-12 col-xs-12"> <ul> <li class="col-lg-3 col-md-3 col-sm-3 col-xs-6"> <h3>网站制作</h3> <a href="http://chengdu.cdcxhl.com/" target="_blank">成都营销网站制作</a><a href="https://www.cdxwcx.com/wangzhan/shop.html" target="_blank">成都商城网站制作</a><a href="http://www.cxhljz.cn/" target="_blank">成都网站制作</a><a href="https://www.cdcxhl.com/" target="_blank">成都网站制作</a><a href="http://www.cdxwcx.cn/" target="_blank">成都网站制作公司</a><a href="http://www.dzwzjz.com/" target="_blank">达州网站制作</a> </li> <li class="col-lg-3 col-md-3 col-sm-3 col-xs-6"> <h3>企业服务</h3> <a href="https://www.cdcxhl.com/link/" target="_blank">友情链接出售</a><a href="https://www.cdcxhl.com/service/shipinxuke.html" target="_blank">食品经营许可证</a><a href="https://www.cdcxhl.com/weihu/chengdu.html" target="_blank">成都网站维护</a><a href="https://www.cdcxhl.com/service/zzgj.html" target="_blank">备案资质管家服务</a><a href="https://www.cdcxhl.com/shoulu/" target="_blank">分类目录</a><a href="https://www.cdcxhl.com/shoulu/" target="_blank">网站快速收录</a> </li> <li class="col-lg-3 col-md-3 col-sm-3 col-xs-6"> <h3>网站建设</h3> <a href="http://chengdu.cdweb.net/" target="_blank">成都网站建设</a><a href="http://m.cdcxhl.com/dingzhi.html" target="_blank">定制网站建设多少钱</a><a href="http://www.kswsj.cn/" target="_blank">成都网站建设</a><a href="http://www.cdkjz.cn/fangan/zhuangshi/" target="_blank">装饰公司网站建设方案</a><a href="http://www.cxjianzhan.com/" target="_blank">成都网站建设公司</a><a href="https://www.cdxwcx.com/city/pengzhou/" target="_blank">彭州网站建设</a> </li> <li class="col-lg-3 col-md-3 col-sm-3 col-xs-6"> <h3>服务器托管</h3> <a href="https://www.cdcxhl.com/idc/yidong.html" target="_blank">移动服务器托管</a><a href="https://www.cdcxhl.com/idc/cqstsanx.html" target="_blank">重庆水土三线托管</a><a href="https://www.cdcxhl.com/cqtuoguan.html" target="_blank">重庆服务器托管</a><a href="https://www.cdxwcx.com/jifang/xiyun.html" target="_blank">成都西云机房</a><a href="https://www.cdcxhl.com/idc/ziyang.html" target="_blank">资阳天府云计算中心</a><a href="http://www.cdxwcx.cn/tuoguan/mianyang.html" target="_blank">绵阳托管服务器</a> </li> </ul> </div> <div class="footar fl col-lg-4 col-md-4 col-sm-12 col-xs-12"> <p>全国免费咨询:</p> <b>400-028-6601</b> <p>业务咨询:028-86922220 / 13518219792</p> <p>节假值班:18980820575 / 13518219792</p> <p>联系地址:成都市太升南路288号锦天国际A幢1002号</p> </div> </div> <div class="footb"> <div class="copy container"> <div class="fl">Copyright © 成都创新互联科技有限公司重庆分公司 <a href="https://beian.miit.gov.cn/" target="_blank">渝ICP备2021005571号</a></div> <!--<div class="fr"><a href="https://www.cdxwcx.com/" target="_blank">成都网站建设</a>:<a href="https://www.cdcxhl.com/" target="_blank">创新互联</a></div>--> </div> </div> <div class="link"> <div class="container"> 友情链接:: <a href="https://www.cdcxhl.com/" target="_blank">成都网站建设</a> <a href="https://www.cdcxhl.com/city/chongqing.html" target="_blank">重庆网站建设</a> <a href="">四川网站建设</a> <a href="">重庆建设网站</a> <a href="https://www.cdxwcx.com/jifang/xiyun.html" target="_blank">移动服务器托管</a> <a href="http://www.cdfuwuqi.com/" target="_blank">成都服务器托管</a> <a href="https://www.cdcxhl.cn/" target="_blank">云服务器</a> <a href="http://www.cdhuace.com/" target="_blank">广告设计制作</a> <a href="https://www.cdcxhl.com/sheji/chongqing.html" target="_blank">重庆网页设计</a> <a href="https://www.cdcxhl.com/zuo/chongqing.html" target="_blank">重庆做网站</a> <a href="https://www.cdcxhl.com/zhizuo/chongqing.html" target="_blank">重庆网站制作</a> <a href="">重庆网站建设</a> <a href="">重庆网站公司</a> <a href="">渝中网站制作</a> <a href="">重庆网站设计</a> </div> </div> </div> <div class="foot"> <ul class="public-celan"> <li> <a href="https://p.qiao.baidu.com/cps3/chatIndex?siteToken=6ce441ff9e2d6bedbdfc2a4138de449e&speedLogId=162260383240185e3_1622603832401_02407&eid=6256368&reqParam=%7B%22from%22%3A1%2C%22sessionid%22%3A%22-100%22%2C%22siteId%22%3A%2211284691%22%2C%22tid%22%3A%22-1%22%2C%22userId%22%3A%226256368%22%2C%22ttype%22%3A1%2C%22pageId%22%3A0%7D" target="_blank" class="a1 db tc"> <img src="/Public/Home/img/icon-23.png" alt="" class="db auto"> <span class="span-txt">在线咨询</span> </a> </li> <li> <a href="tel:18980820575" class="a1 db tc"> <img src="/Public/Home/img/icon-24.png" alt="" class="db auto"> <span class="span-txt">电话咨询</span> </a> </li> <li> <a target="_blank" href="tencent://message/?uin=1683211881&Site=&Menu=yes" class="a1 db tc"> <img src="/Public/Home/img/icon-25.png" alt="" class="db auto"> <span class="span-txt">QQ咨询</span> </a> </li> <li> <a target="_blank" href="tencent://message/?uin=532337155&Site=&Menu=yes" class="a1 db tc public-yuyue-up"> <img src="/Public/Home/img/icon-26.png" alt="" class="db auto"> <span class="span-txt">预约顾问</span> </a> </li> </ul> </div> <div class="customer"> <dl class="icon1"> <dt> <a href="tencent://message/?uin=1683211881&Site=&Menu=yes"> <i class="iconT"><img src="/Public/Home/img/QQ.png" alt=""></i> <p>在线咨询</p> </a> </dt> </dl> <dl class="icon2"> <dt><i><img src="/Public/Home/img/weixin.png" alt=""></i><p>微信咨询</p></dt> <dd><img src="/Public/Home/img/ewm.png"></dd> </dl> <dl class="icon3"> <dt><i><img src="/Public/Home/img/dianhua.png" alt=""></i><p>电话咨询</p></dt> <dd> <p>028-86922220(工作日)</p> <p>18980820575(7×24)</p> </dd> </dl> <dl class="icon4"> <dt class="sShow"> <a href="tencent://message/?uin=244261566&Site=&Menu=yes"> <i><img src="/Public/Home/img/dengji.png" alt=""></i><p>提交需求</p> </a> </dt> </dl> <dl class="icon5"> <dt class="gotop"> <a href="#top"> <i><img src="/Public/Home/img/top.png" alt=""></i><p>返回顶部</p> </a> </dt> </dl> </div> </body> </html> <script> $(".con 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>