1. 问题处理
1.1 2024/3/25
1.1.1 Gihub action中增加的环境变量无法识别
解决需要在jobs上加上环境变量名
1.2 2024/3/26
1.2.1 github action中提交代码step提示无权限
**Error:**Error: Pushing to <u>https://github.com/ftyszyx/myblog</u>
[56](https://github.com/ftyszyx/myblog/actions/runs/8423006609/job/23063634395#step:8:59)remote: Permission to ftyszyx/myblog.git denied to github-actions[bot].
怀疑是权限问题,
查看permision 文档:https://docs.github.com/en/actions/using-jobs/assigning-permissions-to-jobs
加了permision:
又有新的报错
error: failed to push some refs to '<u>https://github.com/ftyszyx/myblog</u>'
知道原因了,我搞了两次提交,
导致异常,合并成一次提交,就好了
1.2.2 pages build and deployment 怎么去掉
Github 上配了pages。会自动加了一个workflow
我想定制这一流程,选这个
然后把这个workflow右边的run log全删除
这个workflow就消失了,世界清静了!
1.2.3 preview时发现cover图片找不到
看了build的结果,cover中的图片的确是没有
因为cover中的图片写在了vitepress page meta中
有可能vitepress认为这里的资源是无效的,应该只用纯文本
参考:https://vitepress.dev/guide/frontmatter
解决方案是把图片放到(不太好)
https://vitejs.dev/guide/assets.html#the-public-directory
在build end中加hook,自己复制过去
buildEnd: async (siteconfig) => {
const coverurls: string[] = await createContentLoader("/*.md", {
excerpt: true,
includeSrc: false,
render: false,
transform: (rawData) => {
return rawData
.filter(({ frontmatter }) => frontmatter.cover)
.map(({ frontmatter }) => {
return frontmatter.cover;
});
},
}).load();
coverurls.forEach((item) => {
const picpath = path.join(siteconfig.root, item);
const picfile_name = path.basename(picpath);
const destpath = path.join(
siteconfig.outDir,
siteconfig.assetsDir,
picfile_name,
);
// console.log("write", picpath, destpath);
copyFileSync(picpath, destpath);
});
},
1.3 2024/3/27
1.3.1 github部署后,因为base路径不对,导致 网页显示异常
因为github page网址是https://ftyszyx.github.io/myblog
所以 baseurl要修改一下
还有问题,这个basepath修改了后,vitepress不会处理cover的链接
Vitepress有接口,可以在网页中获取base
https://vitepress.dev/guide/asset-handling#base-url
1.4 2024/3/28
1.4.1 页面样式太丑,需要调整
尤其是siderbar太宽,内容太窄
1.4.2 增加搜索
vitepress内部支持
1.4.3 增加评论
用artalk实现,需要自己搭服务器
1.5 2024/3/29
1.5.1 多语言支持
毕竟是展示自己用的,还是要加英语,
英文可以通过机器生成,框架参考官方。
先找个参考的软件,我经常使用一款插件:沉浸式翻译
https://immersivetranslate.com/
https://github.com/immersive-translate/immersive-translate/
他是用google翻译的,效果还行
找一下相关的gogole 翻译npm 库
用这个库https://github.com/vitalets/google-translate-api?tab=readme-ov-file#readme
但免费的google 翻译有限制
如果提示有次数限制了,需要用代理,这里有免费的代理
太麻烦了,换微软件 的
https://github.com/plainheart/bing-translate-api
1.5.2 增加点击统计
目前找到的只能统计点击 数,但我还想看到整 个网站的所有点击,并能排序
这就需要一个汇总功能
看有一个开源项目https://github.com/ftyszyx/umami
看能不能在上面改一下实现
umami挺强大,功能很完善。值得学习,使用next.js,前后端一套代码
而且数据库是在yarn build时就初始化了,很优秀
参考其代码增加api
export interface MyblogWebInfo {
url_path: string;
num: number;
}
export interface MyBlogResp {
list: MyblogWebInfo[];
}
export default async (
req: NextApiRequestQueryBody<MyblogReq>,
res: NextApiResponse<MyBlogResp>,
) => {
const views = await getBlogStats(req.query);
// console.log('get views', views);
return ok(res, { views });
};
同时要处理跨域问题
修改next.config.js的headers返回
{
source: '/api/:path*',
headers: [
{ key: 'Access-Control-Allow-Credentials', value: 'true' },
{ key: 'Access-Control-Allow-Origin', value: '*' }, // replace this your actual origin
{ key: 'Access-Control-Allow-Methods', value: 'GET,DELETE,PATCH,POST,PUT' },
{
key: 'Access-Control-Allow-Headers',
value:
'X-CSRF-Token, X-Requested-With, Accept, Accept-Version, Content-Length, Content-MD5, Content-Type, Date, X-Api-Version',
},
],
},
这里还有一个点是要去注册一个自己的container账号
这个cotainer 是上传到ghcr.io这是github cotainer
https://www.chenshaowen.com/blog/github-container-registry.html
官方文档
https://docs.github.com/en/actions/publishing-packages/publishing-docker-images
Github cotainer reg
所以先要搞acess tokens
1.5.3 增加浏览统计
参考这个
https://clarity.microsoft.com/
使用了一下,也正常能用了,就是在chrome上发现很多报错
vitepress third-party cookie will be blocked. clarity
在network上看到
感觉应该是clarity导致 的
先关了,看到报错有不心烦
1.6
1.7 2024/4/7
1.7.1 怎么cloude page
https://www.misterma.com/archives/901/
搞定了,感觉cloudeflare做的真是友好。
不过访问速度还是慢,还是要考虑一下国内部署
1.7.2 阿里云域名申请
买了一个域名bytefuse.cn 字节融合的意思,
感觉挺符合这个项目的,因为这是把飞书和vitepress打通的一个项目。
同时 还有另外一个含义,byte就是表示计算机,打通计算机和人之前的桥梁。多酷啊
域名买 完后就要去备案了 。
遇到个填空,要写网站名
但里面有名称指引:
好奇怪哦,个人网站为什么不能用“博客”这个关键字。有点奇葩
算了,服了,随便取一个吧,星城起点
点提交,提示
好吧,效率真是低下。买 了域名,已经实名过了,还要等2到3天。那只能2到3天后再试了
已经提交了,
过一个月后再看
2. 2024/4/19
2.1 markdown中的tailwind样式不生效
已处理,也不清楚啥问题,照着别人的项目改了一下就Ok了
3. 2024/4/20
3.1 图片加载被截:
参考公众号的图片:
需要两种大小:一是1:1 一是2.35:1
所以我们先2.35:1吧,大小
高度是160宽度就是376
高度是320宽度就是752
高度是800宽度就是1880
3.2 首页的图片经常不加载
3.3 翻译后,编译文档报错
SyntaxError: Element is missing end tag.
看不出是哪个文档编译错误
只能一个个删除,找到对应问题文档
发现里面有<这种符号。删除就Ok了
4. 2024/4/21
4.1 备案通过
还没完,要去下app
必须要手机上注册,因为需要人脸识别
4.2 markdown中图片希望居中
给imag 加一个tailwind属性 m-auto
5. 2024/4/25
5.1 服务器国内自部署
我晕:
vitepress编译时,把服务器搞崩了
我买 的这个99块的服务器,真是够弱的
能不能让github帮我编译好,然后我去下载呢?
5.2 博客分类不对
已处理
5.3 需要自己服务器上的博客也能自动触发更新
5.4 https证书
搞定了,使用let's encrypt 同时配合nginx_ui自动化更新
5.5 Github action触发资源提交不会触发另一个github action
原来我用的是on:push
但是我的提交是用github action提交的,
有可能没有触发push
所以干脆,直接用定时吧,每天触发一次
6. 2024/5/14
1、zip文件 没有打包
已处理:在buildend时将zip文件全复制过去
2、顶部样式有点异常
已处理
7. 2024/5/19
需要给博客搞seo,不然没人访问
首先要生成sitemap站点地图
vitepress自带支持
https://vitepress.dev/guide/sitemap-generation
生成后sitemap.xml就可以直接访问了
https://ftyszyx.github.io/feishu-vitepress/sitemap.xml
参考:https://github.com/mqyqingfeng/Blog/issues/272
7.1 去百度收录
登陆百度搜索资源平台,进入用户中心:
点击「添加站点」,可能需要你完善下账户信息,然后会进入站点信息填写页面,分为三步:
第一步:输入站点
第三步:验证网站
之所以需要验证网站,是为了证明你是该域名的拥有者,验证成功后,可以快捷批量添加子站点,查看所有子站数据,无需再一一验证子站点。
使用html验证
然后点击「完成验证」,就会出现:
点击「我知道了」,就会跳转到 HTTPS 认证这里:
等待一天后,会显示认证成功:
但是有个问题:
普通收录的sitemap方式提交没有次数,不知道是不是要交钱
只能api提交
写了代码,但是提交时提示
{"error":400,"message":"over quota"}
网上说是因为没有提交次数了
在百度后台也查看不昨天提交的审核状态
7.2 谷歌收录
添加域名:
添加dns解析
去阿里去添加
最后去添加索引
一直提示无法抓取
7.3 访问单独某一页时会404
nginx配置错误:
之前是
root /usr/share/nginx/html/appname/;
location / {
index index.html index.htm;
}
需要改成
#open gzip
gzip on;
gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;
#
index index.html;
location / {
# content location
root /app;
# exact matches -> reverse clean urls -> folders -> not found
try_files $uri $uri.html $uri/ =404;
#因为资源文件的名字都是hash,如果有修改名字会变,所以开启永久缓存
# adjust caching headers
# files in the assets folder have hashes filenames
location ~* ^/assets/ {
expires 1y;
add_header Cache-Control "public, immutable";
}
}
原理是,当配置try_files
找不到某个页面资源,这时,nginx会尝试加载index.html,加载index.html之后,react-router就能起作用并匹配我们输入的/home
路由,从而显示正确的home页面。
8. 2024/7/4
8.1 blog.bytefuse.cn无法访问
好几天没上去看了,发现自己部署在阿里云上的博客无法访问了。
登陆上nginx_ui看了下,访问正常
登陆到服务器上看资源目录:发现/var/www/qinglong/web下的资源目录是空的。
上青云的自动任务看执行日志,发现有报错:
好像是从github上下载的zip文件包是坏的。
进入github账号看了下项目下的发布资源,打包是正常的
打的包是12M。但是青云脚本下的是16K。我怀疑是我用的github镜像地址出了问题。当时为了加速github资源下载,使用了https://hub.gitmirror.com/。看来这个镜像现在不能用了。
上ghproxy上看了一下,原来被墙了。
需要使用新的地址:https://mirror.ghproxy.com。
现在Ok了。
不过还有一个问题就是,这个青云同步脚本,在zip文件没下载好,就把web目录下内容清空了,的确不友好。
要加一下判断,如果zip下下来的文件是坏的,就不清空web目录。
9. 待处理问题
1、如何同步到公众号,知乎,csdn
目前已知有
通过服务器推送文章到公众号: