当前位置: 首页 > wzjs >正文

网站建设行业论坛网站制作的流程是什么

网站建设行业论坛,网站制作的流程是什么,王占山军衔,wordpress eshop 中文9年前自己开始学习gitHub hexo搭建个人博客,查了很多资料,最后用hexo 搭建一个个人博客,托管在gitHub上,前段时间换了一个电脑,我在新的电脑上想再发布一篇文章,才发现不行了。因为之前只在GitHub托管了hex…

9年前自己开始学习gitHub hexo搭建个人博客,查了很多资料,最后用hexo 搭建一个个人博客,托管在gitHub上,前段时间换了一个电脑,我在新的电脑上想再发布一篇文章,才发现不行了。因为之前只在GitHub托管了hexo生成的静态文件(public),忘记备份Hexo的源文件。
source/_posts/(所有文章)
_config.yml(Hexo 主配置)
themes/(主题文件)
package.json(依赖列表)
如果你遇到这种情况,跟着我进入接下来的重新部署过程。

gitHub hexo 个人博客基础版。

首先确认你本地已经不存在source/_posts文件夹,再查一查github是否有备份,如何远程和本地都没有,那就只能重新部署了。

1.静态文件(如 public/ 下的 HTML)可通过浏览器右键「查看页面源代码」复制正文,或使用工具解析 HTML 结构。

2.使用 Markdown 渲染,HTML 中的 “article ”标签内通常包含原始文本的转换结果。

3.生成.md文件放在_posts文件夹里面。

1.备份Hexo的源文件

到这里就可以重新发布文章了,但是为了下一次不要再出现这种情况,我们需要对Hexo的源文件进行备份。

备份方式共有两种:

1.在当前gitHub管理的hexo生成的静态文件仓库中再开一个分支,用于备份Hexo的源文件。

2.单独创建一个私有仓库用于备份Hexo的源文件。

因为博客需要对外展示,所以当前gitHub管理的hexo生成的静态文件仓库必须是公开的,所以如果你选择第一种方式你的原文件也只能放在公开的仓库分支。如果不想将自己的Hexo的源文件公开就可以选择第二种方式:单独创建一个私有的仓库用来备份Hexo的源文件。

2.自动化

上文创建完成后每次发布博客,都需要去git提交备份文件,这样太麻烦了。我们可以创建一个自动化脚本,将这些重复步骤自动化。

创建一个deploy.sh放在博客根目录:

# 设置绝对路径
BLOG_DIR="实际路径/blog"# 进入博客目录
cd "$BLOG_DIR" || exit 1# Hexo操作
hexo clean
hexo generate
hexo deploy# 源文件备份
git add .
git commit -m "自动备份: $(date +"%Y-%m-%d %H:%M")"
git push origin main

这样一个简单的发布博客并且源文件备份的自动化脚本就好了。
以后每一次写完文章后再在终端进入"实际路径/blog" 执行./deploy.sh 就行了

执行./deploy.sh

首次执行需要先设置执行权限:

chmod +x deploy.sh

3.多博客自动化

当我们有多个博客需要同步是就需要对Hexo的源文件进行再次修改。

我以github为例:

1.首先我们的有两个GitHub账号并且本地配置好SSH

本地SSH配置

2.添加配置文件

_config.yml:为其中一个GitHub账号的配置

url: https://gavincarter1991.github.io# 博客完整URL

deploy

_config_other.yml:为另外一个GitHub账号的配置

url: https://kindyourself.github.io # 博客完整URL

deploy

考虑到多个博客内容可能不一样:在根目录新建一个scripts文件夹创建一个JS脚本multi-site.js进行内容配置,公共文章放在source/_posts,不同的文章各自放在自己的目录里面(source/_posts_gavin source/_posts_gavin _posts_kind)脚本会分开发布。

const fs = require('fs-extra');
const path = require('path');hexo.extend.filter.register('before_generate', function() {const baseDir = hexo.base_dir;const sites = [{ name: 'kind', postDir: '_posts_kind', config: '_config.yml' },{ name: 'gavin', postDir: '_posts_gavin', config: '_config_gavin.yml' }];sites.forEach(site => {const sourceDir = path.join(baseDir, 'source');const tempSourceDir = path.join(baseDir, `temp_source_${site.name}`);const sitePostsDir = path.join(baseDir, site.postDir);hexo.log.info(`准备 ${site.name} 站点内容...`);try {// 创建临时源目录fs.ensureDirSync(tempSourceDir);fs.emptyDirSync(tempSourceDir);// 复制共享内容fs.copySync(sourceDir, tempSourceDir);// 添加专属文章if (fs.existsSync(sitePostsDir)) {const targetPostsDir = path.join(tempSourceDir, '_posts');fs.ensureDirSync(targetPostsDir);fs.readdirSync(sitePostsDir).forEach(file => {if (file.endsWith('.md')) {fs.copySync(path.join(sitePostsDir, file),path.join(targetPostsDir, file));}});}// 更新配置中的source_dirconst configPath = path.join(baseDir, site.config);let configContent = fs.readFileSync(configPath, 'utf-8');configContent = configContent.replace(/source_dir:.+/,`source_dir: ${tempSourceDir}`);fs.writeFileSync(configPath, configContent);hexo.log.info(`${site.name} 站点内容准备完成`);} catch (e) {hexo.log.error(`${site.name} 站点准备失败: ${e.message}`);}});
});

当然deploy.sh也需要更改为:

#!/usr/bin/env bash# 配置区
BLOG_DIR="/自己路径/blog"
SOURCE_BRANCH="master"
PUBLIC_REPO_KIND="git@github.com-kind:kindyourself/kindyourself.github.io.git"
PUBLIC_REPO_GAVIN="git@github.com-gavin:gavincarter1991/gavincarter1991.github.io.git"
PRIVATE_REPO_KIND="git@github.com-kind:kindyourself/blog-source.git"
PRIVATE_REPO_GAVIN="git@github.com-gavin:gavincarter1991/blog-source.git"cd "$BLOG_DIR" || { echo "❌ 无法进入博客目录"; exit 1; }# 清理上次生成的临时文件
rm -rf temp_source_* public public_gavin# 生成两个站点的内容
echo "===== 生成站点内容 ====="
hexo generate --config _config.yml
hexo generate --config _config_gavin.yml# 部署到GitHub Pages
echo "===== 部署到GitHub Pages ====="
hexo deploy --config _config.yml
hexo deploy --config _config_gavin.yml# 备份到私有仓库
echo "===== 备份源文件到私有仓库 ====="
git add .
if git diff-index --quiet HEAD --; thenecho "无文件变更"
elsegit commit -m "自动备份: $(date +"%Y-%m-%d %H:%M:%S")"# 推送到两个私有仓库git push "$PRIVATE_REPO_KIND" "$SOURCE_BRANCH" && \echo "✅ kindyourself/blog-source 备份成功" || \echo "❌ kindyourself/blog-source 备份失败"git push "$PRIVATE_REPO_GAVIN" "$SOURCE_BRANCH" && \echo "✅ gavincarter1991/blog-source 备份成功" || \echo "❌ gavincarter1991/blog-source 备份失败"
fiecho "===== 部署完成 ====="
echo "博客地址1: https://kindyourself.github.io"
echo "博客地址2: https://gavincarter1991.github.io"

以上就是gitHub hexo 个人博客升级版

http://www.dtcms.com/wzjs/230499.html

相关文章:

  • 个人怎么注册小微企业福州seo排名优化公司
  • 加上web.config 网站500阿里指数查询入口
  • 广告推广网站怎么做厦门人才网招聘最新信息
  • 重庆网站模板平台建设建网站免费
  • 公司做seo网站b2b推广网站
  • 建筑公司查询网站学大教育培训机构电话
  • 网站建设方案书 内容管理制度代刷网站推广快速
  • 关键词优化提升排名郑州seo教程
  • 杭州做网站的优质公司哪家好济南百度公司
  • 商城网站建设网络公司免费域名
  • 移动网站开发教材西安关键词网站排名
  • 网站推广工作好做吗临沂森佳木业有限公司
  • 网站建设教程视频5118关键词工具
  • 有个网站做中日韩测试互联网广告推广是什么
  • 阿里巴巴网站头像你会放什么做头像东莞seo网络推广专
  • 花钱做网站注意什么想做网络推广的公司
  • ztouchs网站查询个人模板建站
  • 哪些外国购物网站可以做西安自助建站
  • 新手学做网站 下载alexa全球网站排名分析
  • 免费网站重生九零做商女专业的网页制作公司
  • 网站开发建设付款方式企业内训机构
  • 山西建站推广拉新推广
  • 丹徒网站建设包括哪些seo到底是做什么的
  • 互站网源码商城口碑营销公司
  • 温州市建设工程质量安全管理总站百度搜索竞价排名
  • 网站建设维护和网页设计拓客软件
  • 网站流量30g网络营销策划方案论文
  • 网站布局今日新闻国家大事
  • 建立个网站seo推广优化培训
  • 大连网站制作多少钱2023全民核酸又开始了