元旦在家写代码,我完成了一个Markdown利器Typora私有化图床工具~ Windows, macOS,Linux均可运行

EasyTypora

EasyTypora是一个为Typora添加私用化图床的实用小工具,要使用本项目,你需要有自己的一台云服务器~

本项目永久地址:
https://github.com/zhaoolee/EasyTypora

通过这个项目你能得到什么?

  • 在2021年,配合Typora使用,即使不买图床,也能获得极致的Markdown写作体验。
  • 学会手动安装Node.js的任意版本。
  • 体验Node.js神库pkg的跨平台编译,你将获得Windows, macOS, Linux三个平台的可执行文件,配合各个平台的Typora一起使用

最终效果

image

项目特色

  • 跨平台!无论你使用macOS, Windows, Linux, 都可以使用本工具
  • 开箱即用,部署简单, 本项目不需要复杂的配置项,你可以直接将本项目直接git clone到服务器,npm run build 获取客户端, npm start 开启服务端,然后就可以愉快使用了
  • 图床私用化,无需担心被别人白嫖流量,如果你想分享给同伴,可以直接送一个可执行文件的客户端。
  • 如果客户端泄露,被人滥用,可以在服务端全自动生成新的可执行文件,旧版本的可执行文件直接作废!
  • 可以和Nginx配合使用,不小心Kill掉了图床程序,已上传图片访问不受影响。

如何实现图床私有化加密?(避免白嫖)

用户可进入根目录下的conf.js文件,为secret_conf字段加入随机字符串(随便填一些字符),进行加密。

为secret_conf添加的字符串,会自动构建到到客户端和服务端,完全不需要记

如何实现Typora跨平台私有化图床上传工具?

Typora自定义图床,需要一个可执行文件,而Windows与Linux的shell脚本不可能通用,于是zhaoolee使用Node.js完成了客户端的编写,并使用Node.js神器pkg完成了跨平台打包(macOS, Windows, Linux都支持)

图片如何存放?

用户上传的图片,存储在项目中 server/assets 目录里,如果要迁移到其它服务器,可以跟着项目一起打包运走。

为了避免文件名重复,程序会自动为图片文件重新命名。

为了方便日后确定图片上传时间,命名会自动添加时间戳。

这个图床服务可以单独拆出来,给其它网页用么?

当然可以!你只需满足file,secret_token这两个字段,就可以在网页使用,具体实现方式参考 client/typora.js ,开源代码绝不作假

如果你想省略传secret_token字段,那把conf.js里面的secret_token字段, 改成 secret_token: "",就好了!

如何部署使用?

本程序分两个部分,客户端和服务端,我们先下载程序到服务器,然后在服务器完成服务端配置,然后编译生成带鉴权秘钥的个性化客户端,使用scp将客户端下载到本地后,无需任何配置,插入Typora即可使用!

安装node.js 环境

cd /opt/
wget https://nodejs.org/dist/v14.0.0/node-v14.0.0-linux-x64.tar.xz
tar xvf node-v14.0.0-linux-x64.tar.xz

  • 将Node.js添加到系统变量 vim
echo "export NODE_HOME=/opt/node-v14.0.0-linux-x64" >> ~/.bashrc
echo "export PATH=\$NODE_HOME/bin:\$PATH" >> ~/.bashrc
source ~/.bashrc

获取最新版本的小程序

cd  /opt/
git clone --depth 1 https://github.com/zhaoolee/EasyTypora.git
cd EasyTypora
# 安装依赖包
npm i 

将conf.js里面的内容改为自己的服务器

module.exports = {
    // 填写域名或ip(带http或https协议,如 http://cdn.fangyuanxiaozhan.com)
    host: "http://cdn.fangyuanxiaozhan.com",
    // 填写服务端运行的端口号(填字符串)
    server_port: "12800",
    // 填写客户端请求的端口号(填字符串)
    client_port: "12800",
    // secret_token (客户端和服务端会同时添加secret_token鉴权,防止被他人滥用) 
    secret_token: "8asadelualdldfgaseasdfasdedadf"
}

  • 服务端的80端口可能已经被nginx占据,如果我们依然想用80端口作为图床对外的服务端口,我们可以配置一层Nginx转发, 比如把server_port 设置为 12800 ,把client_port设置为80, 然后Nginx加上将12800端口的服务转发到80端口即可!
server {
    server_name      cdn.fangyuanxiaozhan.com
    listen           80;

    location / {
        proxy_pass http://127.0.0.1:12800;
        proxy_set_header Host $host:80;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}

启动服务

npm start

服务启动后,访问对应的域名和端口可以看到提示信息

image

添加/info路径,可以除secret_token以外的配置信息

image

关闭服务

npm run stop

构建客户端二进制包

// 同时构建 Linux macOS Windows的二进制包
npm run build

构建完成后,项目的根目录的dist文件夹会出现, 三个构建好的文件

文件名 适用平台
typora-win.exe Windows
typora-mac.app macOS
typora-linux.sh linux
image

我们可以通过scp文件传输服务,把生成的文件保存到本地,然后在本地验证服务

image

如何给图片加https?

我通过Nginx加了https, 唯一需要注意的点是,在conf.js中,如果host配置了https, 那客户端的端口client_port需要设置为443

我在前面http的基础上,给nginx配置做一个http的扩充,以下为参考配置(在/etc/nginx/conf.d中新建一个.conf后缀的文件即可)

server {
    server_name      cdn.fangyuanxiaozhan.com
    listen           80;

    location / {
        proxy_pass http://127.0.0.1:3000;
        proxy_set_header Host $host:80;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}


server {
  listen 443 ssl;   #SSL协议访问端口号为443。此处如未添加ssl,可能会造成Nginx无法启动。
  server_name cdn.fangyuanxiaozhan.com;  #将localhost修改为您证书绑定的域名,例如:www.example.com。
  charset  utf-8;
  root /usr/share/nginx/fangyuanxiaozhan.com;
  index index.php index.html index.htm;
  ssl_certificate /etc/nginx/cert/cdn.fangyuanxiaozhan.com/cdn.fangyuanxiaozhan.com.pem;   #将domain name.pem替换成您证书的文件名。
  ssl_certificate_key /etc/nginx/cert/cdn.fangyuanxiaozhan.com/cdn.fangyuanxiaozhan.com.key;   #将domain name.key替换成您证书的密钥文件名。
  ssl_session_timeout 5m;
  ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;  #使用此加密套件。
  ssl_protocols TLSv1 TLSv1.1 TLSv1.2;   #使用该协议进行配置。
  ssl_prefer_server_ciphers on;   
  gzip on;
  gzip_min_length 1k;
  gzip_buffers 4 16k;
  #gzip_http_version 1.0;
  gzip_comp_level 8;
  gzip_types text/plain application/javascript application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png;
  gzip_vary off;
  gzip_disable "MSIE [1-6]\."; 

  # 如果程序崩溃,只是上传服务受影响,nginx会从静态目录取图片文件
  location /assets/ {
      alias  /opt/EasyTypora/server/assets/;
  }

  location / {
        proxy_pass http://127.0.0.1:3000;
        proxy_set_header Host $host:443;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  }


} 

加Https后,在Linux发行版Deepin中,使用Typory上传图片到私有图床

image

未来的工作

  • 做一个带鉴权的网页,可以批量传图
  • 多写文章,测试这个工具的稳定性(工具用了不到2天写完,多多少少会有bug),修复BUG
  • 以本项目为基础,搞一套WordPress发布程序,这套程序像Hexo一样好用,却又能充分利用WordPress生态的优势

相关资源

Typora的Mac,Windows, Linux安装包备份:https://zhaooolee.cowtransfer.com/s/1fb5b95cf46a4f

pkg跨平台打包依赖文件备份(希望你的网络环境很好,用不到这玩意儿): https://zhaooolee.cowtransfer.com/s/05e7feb42c814d

最后放几张私有图床的图片

13cf7ac5a8cbafdbc4e70c69d3a42dee
AttackingGiant
GirlInTheRain
StarrySkyCastle
SuperHero
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容