把GitHub作为图床
背景
最近又迷恋上了写博客,尤其是前一段时间很想要写点东西分享一些软件的使用感想。但当写完文章想要发表时就会碰到一个问题:由于我是现在本机的编辑器中用 Markdown 写好了全文的内容,再发表到各个平台(曾经是 GitHub Pages 搭建的博客,后来又多了简书,现在再加上 SegmentFault)上的,因此文章里的图片都是引用在本地磁盘上的文件路径的。这么一来,如果直接将文章源码粘贴到博客平台上——比如粘贴到 SegmentFault 中,那么这些本地的图片链接就无法在发布后的文章中正常显示了。
如果一开始就在 SegmentFault 中写作也会遇到问题。SegmentFault 上的文章插入图片后,并不是像普通的 Markdown 源码那般插入一条![]()形式的标记的,而是像下图这样
在SegmentFault中插入图片后的效果
显然,这样的文章源码复制到其它平台(GitHub Pages、简书)去发布的话,必然是需要针对其中的图片标记修改一番的——比刚开始的方法或许要更麻烦。
看来要解决这个图片链接在不同平台间共用的问题,必须有一处纯粹的用于存放图片文件的地方——也就是大家常说的图床了。刚开始我也放狗搜了一下,看看别人的推荐,印象中得到的答复不外乎是又 ○ 云、七 ○ 云、新 ○ 微博,以及sm.ms等。但它们要么需要注册并且实名认证,要么不纯粹,要么让人觉得随时会丢失。
某个晚上忽然想到,GitHub 不就是一个很好的图床么?!在 GitHub 上建一个仓库专门存放博客中的图片,不仅免费、完全受自己管理,而且自带 CDN 加速,并且我的读者群(如果真的有这么一个群体的话)也应当可以畅通地访问 GitHub。
放图片的仓库虽然有了,但用起来还不是很便利——因为作为写作素材的图片在我的电脑上是存放在一个单独的、非 GitHub 仓库的目录下的,所以如果要丢到图床上,就需要先将文件复制过去,然后执行 git 的 add、commit、push 三部曲,最后还要到 GitHub 上复制这张新图片的raw地址。
这个过程很机械化,完全可以用一个Alfred的Workflow来代劳。
编写 Workflow
编写 Workflow 就像编写 Common Lisp 中的宏一样,总是从它们的用法入手的。在我的设想中,这个 Workflow 的使用方式应当是:
- 首先,按下快捷键调出 Alfred 的输入框,输入关键字(在我这里就叫做 upload)来唤起这个 Workflow;
- 然后,输入要上传的图片文件的绝对路径并按下回车,开始在后台处理
- 最后,上传完毕后,弹出通知来告诉我
整个 Workflow 的概貌其实很简单
upload Workflow的全貌
第二个节点所调用的 External Script 是长这样子的
!/bin/bash将磁盘文件上传到GitHubpath=${1}pictures_dir="${HOME}/Documents/Projects/riverbed/pictures"cp"${path}""${pictures_dir}"echo文件复制完毕file=$(basename"${path}")cd"${pictures_dir}"git add"${file}"git commit -m上传一张图片git push -u origin masterecho文件已提交到GitHub/usr/local/bin/node -e"console.log(encodeURI(https://raw.githubusercontent.com/Liutos/riverbed/master/pictures/${file}));"| tr -d\n| pbcopy
获取文件的绝对路径其实很简单,在 Finder 中选中文件后,按下 Command+Option+C 即可
这里使用basename命令获取文件名。并且,为了避免git打开文本编辑器要求输入 commit message,向 git-commit 命令传递了-m选项。
因为文件名含有非 ASCII 的字符(毕竟会有中文),需要做一次 URL 编码,因此用了node来做转换。在 Node.js 代码中用console.log输出编码后的图片 URL,结尾会有一个换行符,所以用tr将其去掉。最后,输出的内容重定向给pbcopy,就将上传后的图片 URL 复制到剪贴板中了。如果此时正在编辑文章,便可以粘贴这个图片的链接到源码中。
Alfred 也提供Copy to Clipboard,用于将 Workflow 中上一个节点的输出复制到剪贴板中。之所以不使用,其实是因为刚开始的时候就是用的 Alfred 的Copy to Clipboard,结果发现git运行过程中的输出也被 Alfred 接收了,跟图片 URL 一起混进了剪贴板中。所以最后改为直接调用pbcopy。
全文完。
本文使用mdnice排版
具体使用方法
1、使用VNC Viewer或者浏览器登录容器
dockerrun-itd-p6080:80-p5900:5900dorowu/ubuntu-desktop-lxde-vnc:bionic
GitHub最好用的docker镜像,内置网页版VNC
镜像名称dorowu/docker-ubuntu-vnc-desktop